@decaf-ts/for-couchdb 0.3.0 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +646 -144
- package/README.md +371 -1
- package/dist/for-couchdb.cjs +907 -326
- package/dist/for-couchdb.esm.cjs +910 -329
- package/lib/adapter.cjs +249 -41
- package/lib/adapter.d.ts +243 -17
- package/lib/constants.cjs +30 -2
- package/lib/constants.d.ts +28 -0
- package/lib/errors.cjs +19 -2
- package/lib/errors.d.ts +17 -0
- package/lib/esm/adapter.d.ts +243 -17
- package/lib/esm/adapter.js +249 -41
- package/lib/esm/constants.d.ts +28 -0
- package/lib/esm/constants.js +30 -2
- package/lib/esm/errors.d.ts +17 -0
- package/lib/esm/errors.js +19 -2
- package/lib/esm/index.d.ts +6 -13
- package/lib/esm/index.js +7 -14
- package/lib/esm/indexes/generator.d.ts +47 -0
- package/lib/esm/indexes/generator.js +58 -1
- package/lib/esm/interfaces/CouchDBRepository.d.ts +10 -0
- package/lib/esm/interfaces/CouchDBRepository.js +1 -1
- package/lib/esm/model/CouchDBSequence.d.ts +15 -9
- package/lib/esm/model/CouchDBSequence.js +12 -1
- package/lib/esm/query/Paginator.d.ts +117 -4
- package/lib/esm/query/Paginator.js +128 -23
- package/lib/esm/query/Statement.d.ts +141 -8
- package/lib/esm/query/Statement.js +256 -28
- package/lib/esm/query/constants.d.ts +43 -0
- package/lib/esm/query/constants.js +44 -1
- package/lib/esm/query/index.d.ts +4 -1
- package/lib/esm/query/index.js +5 -2
- package/lib/esm/query/translate.d.ts +31 -0
- package/lib/esm/query/translate.js +32 -1
- package/lib/esm/sequences/Sequence.d.ts +0 -2
- package/lib/esm/sequences/Sequence.js +5 -9
- package/lib/esm/types.d.ts +55 -12
- package/lib/esm/types.js +1 -1
- package/lib/esm/utils.d.ts +105 -0
- package/lib/esm/utils.js +106 -1
- package/lib/index.cjs +7 -14
- package/lib/index.d.ts +6 -13
- package/lib/indexes/generator.cjs +58 -1
- package/lib/indexes/generator.d.ts +47 -0
- package/lib/interfaces/CouchDBRepository.cjs +1 -1
- package/lib/interfaces/CouchDBRepository.d.ts +10 -0
- package/lib/model/CouchDBSequence.cjs +12 -1
- package/lib/model/CouchDBSequence.d.ts +15 -9
- package/lib/query/Paginator.cjs +126 -21
- package/lib/query/Paginator.d.ts +117 -4
- package/lib/query/Statement.cjs +255 -27
- package/lib/query/Statement.d.ts +141 -8
- package/lib/query/constants.cjs +45 -2
- package/lib/query/constants.d.ts +43 -0
- package/lib/query/index.cjs +5 -2
- package/lib/query/index.d.ts +4 -1
- package/lib/query/translate.cjs +32 -1
- package/lib/query/translate.d.ts +31 -0
- package/lib/sequences/Sequence.cjs +5 -9
- package/lib/sequences/Sequence.d.ts +0 -2
- package/lib/types.cjs +1 -1
- package/lib/types.d.ts +55 -12
- package/lib/utils.cjs +106 -1
- package/lib/utils.d.ts +105 -0
- package/package.json +2 -2
- package/lib/esm/query/FromClause.d.ts +0 -7
- package/lib/esm/query/FromClause.js +0 -20
- package/lib/esm/query/InsertClause.d.ts +0 -7
- package/lib/esm/query/InsertClause.js +0 -13
- package/lib/esm/query/SelectClause.d.ts +0 -7
- package/lib/esm/query/SelectClause.js +0 -16
- package/lib/esm/query/ValuesClause.d.ts +0 -7
- package/lib/esm/query/ValuesClause.js +0 -12
- package/lib/esm/query/WhereClause.d.ts +0 -7
- package/lib/esm/query/WhereClause.js +0 -57
- package/lib/esm/query/factory.d.ts +0 -25
- package/lib/esm/query/factory.js +0 -117
- package/lib/esm/sequences/utils.d.ts +0 -1
- package/lib/esm/sequences/utils.js +0 -16
- package/lib/query/FromClause.cjs +0 -24
- package/lib/query/FromClause.d.ts +0 -7
- package/lib/query/InsertClause.cjs +0 -17
- package/lib/query/InsertClause.d.ts +0 -7
- package/lib/query/SelectClause.cjs +0 -20
- package/lib/query/SelectClause.d.ts +0 -7
- package/lib/query/ValuesClause.cjs +0 -16
- package/lib/query/ValuesClause.d.ts +0 -7
- package/lib/query/WhereClause.cjs +0 -61
- package/lib/query/WhereClause.d.ts +0 -7
- package/lib/query/factory.cjs +0 -121
- package/lib/query/factory.d.ts +0 -25
- package/lib/sequences/utils.cjs +0 -19
- package/lib/sequences/utils.d.ts +0 -1
package/dist/for-couchdb.esm.cjs
CHANGED
|
@@ -1,12 +1,40 @@
|
|
|
1
|
-
import { Repository, PersistenceKeys, pk, index, table, BaseModel, Sequence as Sequence$1, Paginator, PagingError,
|
|
2
|
-
import { DefaultSeparator, InternalError,
|
|
1
|
+
import { Repository, PersistenceKeys, pk, index, table, BaseModel, Sequence as Sequence$1, Paginator, PagingError, QueryError, Statement, Condition, GroupOperator, Operator, final, Adapter, ConnectionError } from '@decaf-ts/core';
|
|
2
|
+
import { DefaultSeparator, NotFoundError, InternalError, BaseError, findPrimaryKey, prefixMethod, ConflictError } from '@decaf-ts/db-decorators';
|
|
3
3
|
import { __decorate, __metadata } from 'tslib';
|
|
4
|
-
import { required, model
|
|
4
|
+
import { required, model } from '@decaf-ts/decorator-validation';
|
|
5
5
|
import 'reflect-metadata';
|
|
6
6
|
|
|
7
|
+
/**
|
|
8
|
+
* @description Regular expression to identify reserved attributes in CouchDB
|
|
9
|
+
* @summary Matches any attribute that starts with an underscore
|
|
10
|
+
* @const reservedAttributes
|
|
11
|
+
* @memberOf module:for-couchdb
|
|
12
|
+
*/
|
|
7
13
|
const reservedAttributes = /^_.*$/g;
|
|
14
|
+
/**
|
|
15
|
+
* @description Key constants used in CouchDB operations
|
|
16
|
+
* @summary Collection of string constants for CouchDB document properties and operations
|
|
17
|
+
* @typedef {Object} CouchDBKeysType
|
|
18
|
+
* @property {string} SEPARATOR - Separator used for combining table name and ID
|
|
19
|
+
* @property {string} ID - CouchDB document ID field
|
|
20
|
+
* @property {string} REV - CouchDB document revision field
|
|
21
|
+
* @property {string} DELETED - CouchDB deleted document marker
|
|
22
|
+
* @property {string} TABLE - Table name marker
|
|
23
|
+
* @property {string} SEQUENCE - Sequence marker
|
|
24
|
+
* @property {string} DDOC - Design document marker
|
|
25
|
+
* @property {string} NATIVE - Native marker
|
|
26
|
+
* @property {string} INDEX - Index marker
|
|
27
|
+
* @memberOf module:for-couchdb
|
|
28
|
+
*/
|
|
29
|
+
/**
|
|
30
|
+
* @description Key constants used in CouchDB operations
|
|
31
|
+
* @summary Collection of string constants for CouchDB document properties and operations
|
|
32
|
+
* @const CouchDBKeys
|
|
33
|
+
* @type {CouchDBKeysType}
|
|
34
|
+
* @memberOf module:for-couchdb
|
|
35
|
+
*/
|
|
8
36
|
const CouchDBKeys = {
|
|
9
|
-
SEPARATOR: "
|
|
37
|
+
SEPARATOR: "__",
|
|
10
38
|
ID: "_id",
|
|
11
39
|
REV: "_rev",
|
|
12
40
|
DELETED: "_deleted",
|
|
@@ -17,6 +45,30 @@ const CouchDBKeys = {
|
|
|
17
45
|
INDEX: "index",
|
|
18
46
|
};
|
|
19
47
|
|
|
48
|
+
/**
|
|
49
|
+
* @description Default query limit for CouchDB queries
|
|
50
|
+
* @summary Maximum number of documents to return in a single query
|
|
51
|
+
* @const CouchDBQueryLimit
|
|
52
|
+
* @memberOf module:for-couchdb
|
|
53
|
+
*/
|
|
54
|
+
const CouchDBQueryLimit = 250;
|
|
55
|
+
/**
|
|
56
|
+
* @description Mapping of operator names to CouchDB Mango query operators
|
|
57
|
+
* @summary Constants for CouchDB comparison operators used in Mango queries
|
|
58
|
+
* @typedef {Object} CouchDBOperatorType
|
|
59
|
+
* @property {string} EQUAL - Equality operator ($eq)
|
|
60
|
+
* @property {string} DIFFERENT - Inequality operator ($ne)
|
|
61
|
+
* @property {string} BIGGER - Greater than operator ($gt)
|
|
62
|
+
* @property {string} BIGGER_EQ - Greater than or equal operator ($gte)
|
|
63
|
+
* @property {string} SMALLER - Less than operator ($lt)
|
|
64
|
+
* @property {string} SMALLER_EQ - Less than or equal operator ($lte)
|
|
65
|
+
* @property {string} NOT - Negation operator ($not)
|
|
66
|
+
* @property {string} IN - In array operator ($in)
|
|
67
|
+
* @property {string} REGEXP - Regular expression operator ($regex)
|
|
68
|
+
* @const CouchDBOperator
|
|
69
|
+
* @type {CouchDBOperatorType}
|
|
70
|
+
* @memberOf module:for-couchdb
|
|
71
|
+
*/
|
|
20
72
|
const CouchDBOperator = {
|
|
21
73
|
EQUAL: "$eq",
|
|
22
74
|
DIFFERENT: "$ne",
|
|
@@ -30,11 +82,31 @@ const CouchDBOperator = {
|
|
|
30
82
|
// IS = "IS",
|
|
31
83
|
REGEXP: "$regex",
|
|
32
84
|
};
|
|
85
|
+
/**
|
|
86
|
+
* @description Mapping of logical operator names to CouchDB Mango query operators
|
|
87
|
+
* @summary Constants for CouchDB logical operators used in Mango queries
|
|
88
|
+
* @typedef {Object} CouchDBGroupOperatorType
|
|
89
|
+
* @property {string} AND - Logical AND operator ($and)
|
|
90
|
+
* @property {string} OR - Logical OR operator ($or)
|
|
91
|
+
* @const CouchDBGroupOperator
|
|
92
|
+
* @type {CouchDBGroupOperatorType}
|
|
93
|
+
* @memberOf module:for-couchdb
|
|
94
|
+
*/
|
|
33
95
|
const CouchDBGroupOperator = {
|
|
34
96
|
AND: "$and",
|
|
35
97
|
OR: "$or",
|
|
36
98
|
};
|
|
37
99
|
|
|
100
|
+
/**
|
|
101
|
+
* @description Generates a name for a CouchDB index
|
|
102
|
+
* @summary Creates a standardized name for a CouchDB index by combining name parts, compositions, and direction
|
|
103
|
+
* @param {string[]} name - Array of name parts for the index
|
|
104
|
+
* @param {OrderDirection} [direction] - Optional sort direction for the index
|
|
105
|
+
* @param {string[]} [compositions] - Optional additional attributes to include in the index name
|
|
106
|
+
* @param {string} [separator=DefaultSeparator] - The separator to use between parts of the index name
|
|
107
|
+
* @return {string} The generated index name
|
|
108
|
+
* @memberOf module:for-couchdb
|
|
109
|
+
*/
|
|
38
110
|
function generateIndexName$1(name, direction, compositions, separator = DefaultSeparator) {
|
|
39
111
|
return [
|
|
40
112
|
...name.map((n) => (n === CouchDBKeys.TABLE ? "table" : n)),
|
|
@@ -43,6 +115,53 @@ function generateIndexName$1(name, direction, compositions, separator = DefaultS
|
|
|
43
115
|
CouchDBKeys.INDEX,
|
|
44
116
|
].join(separator);
|
|
45
117
|
}
|
|
118
|
+
/**
|
|
119
|
+
* @description Generates CouchDB index configurations for models
|
|
120
|
+
* @summary Creates a set of CouchDB index configurations based on the metadata of the provided models
|
|
121
|
+
* @template M - The model type that extends Model
|
|
122
|
+
* @param models - Array of model constructors to generate indexes for
|
|
123
|
+
* @return {CreateIndexRequest[]} Array of CouchDB index configurations
|
|
124
|
+
* @function generateIndexes
|
|
125
|
+
* @memberOf module:for-couchdb
|
|
126
|
+
* @mermaid
|
|
127
|
+
* sequenceDiagram
|
|
128
|
+
* participant Caller
|
|
129
|
+
* participant generateIndexes
|
|
130
|
+
* participant generateIndexName
|
|
131
|
+
* participant Repository
|
|
132
|
+
*
|
|
133
|
+
* Caller->>generateIndexes: models
|
|
134
|
+
*
|
|
135
|
+
* Note over generateIndexes: Create base table index
|
|
136
|
+
* generateIndexes->>generateIndexName: [CouchDBKeys.TABLE]
|
|
137
|
+
* generateIndexName-->>generateIndexes: tableName
|
|
138
|
+
* generateIndexes->>generateIndexes: Create table index config
|
|
139
|
+
*
|
|
140
|
+
* loop For each model
|
|
141
|
+
* generateIndexes->>Repository: Get indexes metadata
|
|
142
|
+
* Repository-->>generateIndexes: index metadata
|
|
143
|
+
*
|
|
144
|
+
* loop For each index in metadata
|
|
145
|
+
* Note over generateIndexes: Extract index properties
|
|
146
|
+
* generateIndexes->>Repository: Get table name
|
|
147
|
+
* Repository-->>generateIndexes: tableName
|
|
148
|
+
*
|
|
149
|
+
* Note over generateIndexes: Define nested generate function
|
|
150
|
+
*
|
|
151
|
+
* generateIndexes->>generateIndexes: Call generate() for default order
|
|
152
|
+
* Note over generateIndexes: Create index name and config
|
|
153
|
+
*
|
|
154
|
+
* alt Has directions
|
|
155
|
+
* loop For each direction
|
|
156
|
+
* generateIndexes->>generateIndexes: Call generate(direction)
|
|
157
|
+
* Note over generateIndexes: Create ordered index config
|
|
158
|
+
* end
|
|
159
|
+
* end
|
|
160
|
+
* end
|
|
161
|
+
* end
|
|
162
|
+
*
|
|
163
|
+
* generateIndexes-->>Caller: Array of index configurations
|
|
164
|
+
*/
|
|
46
165
|
function generateIndexes(models) {
|
|
47
166
|
const tableName = generateIndexName$1([CouchDBKeys.TABLE]);
|
|
48
167
|
const indexes = {};
|
|
@@ -102,6 +221,17 @@ function generateIndexes(models) {
|
|
|
102
221
|
return Object.values(indexes);
|
|
103
222
|
}
|
|
104
223
|
|
|
224
|
+
/**
|
|
225
|
+
* @description Model for CouchDB sequence records
|
|
226
|
+
* @summary Represents a sequence in CouchDB used for generating sequential IDs
|
|
227
|
+
* @param {ModelArg<Sequence>} [seq] - Optional initialization data for the sequence
|
|
228
|
+
* @class
|
|
229
|
+
* @example
|
|
230
|
+
* // Example of creating and using a Sequence
|
|
231
|
+
* const sequence = new Sequence({ id: 'user-seq', current: 1 });
|
|
232
|
+
* // Increment the sequence
|
|
233
|
+
* sequence.current = Number(sequence.current) + 1;
|
|
234
|
+
*/
|
|
105
235
|
let Sequence = class Sequence extends BaseModel {
|
|
106
236
|
constructor(seq) {
|
|
107
237
|
super(seq);
|
|
@@ -122,21 +252,6 @@ Sequence = __decorate([
|
|
|
122
252
|
__metadata("design:paramtypes", [Object])
|
|
123
253
|
], Sequence);
|
|
124
254
|
|
|
125
|
-
function parseSequenceValue(type, value) {
|
|
126
|
-
switch (type) {
|
|
127
|
-
case "Number":
|
|
128
|
-
return typeof value === "string"
|
|
129
|
-
? parseInt(value)
|
|
130
|
-
: typeof value === "number"
|
|
131
|
-
? value
|
|
132
|
-
: BigInt(value);
|
|
133
|
-
case "BigInt":
|
|
134
|
-
return BigInt(value);
|
|
135
|
-
default:
|
|
136
|
-
throw new InternalError("Should never happen");
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
|
|
140
255
|
/**
|
|
141
256
|
* @summary Abstract implementation of a Sequence
|
|
142
257
|
* @description provides the basic functionality for {@link Sequence}s
|
|
@@ -145,13 +260,11 @@ function parseSequenceValue(type, value) {
|
|
|
145
260
|
*
|
|
146
261
|
* @class CouchDBSequence
|
|
147
262
|
* @implements Sequence
|
|
148
|
-
*
|
|
149
|
-
* @category Sequences
|
|
150
263
|
*/
|
|
151
264
|
class CouchDBSequence extends Sequence$1 {
|
|
152
265
|
constructor(options, adapter) {
|
|
153
266
|
super(options);
|
|
154
|
-
this.repo = Repository.forModel(Sequence, adapter.
|
|
267
|
+
this.repo = Repository.forModel(Sequence, adapter.alias);
|
|
155
268
|
}
|
|
156
269
|
/**
|
|
157
270
|
* @summary Retrieves the current value for the sequence
|
|
@@ -171,10 +284,10 @@ class CouchDBSequence extends Sequence$1 {
|
|
|
171
284
|
return this.parse(startWith);
|
|
172
285
|
}
|
|
173
286
|
catch (e) {
|
|
174
|
-
throw new InternalError(
|
|
287
|
+
throw new InternalError(`Failed to parse initial value for sequence ${startWith}: ${e}`);
|
|
175
288
|
}
|
|
176
289
|
}
|
|
177
|
-
throw new InternalError(
|
|
290
|
+
throw new InternalError(`Failed to retrieve current value for sequence ${name}: ${e}`);
|
|
178
291
|
}
|
|
179
292
|
}
|
|
180
293
|
/**
|
|
@@ -184,7 +297,7 @@ class CouchDBSequence extends Sequence$1 {
|
|
|
184
297
|
* @param value
|
|
185
298
|
*/
|
|
186
299
|
parse(value) {
|
|
187
|
-
return
|
|
300
|
+
return Sequence$1.parseValue(this.options.type, value);
|
|
188
301
|
}
|
|
189
302
|
/**
|
|
190
303
|
* @summary increments the sequence
|
|
@@ -245,16 +358,87 @@ class CouchDBSequence extends Sequence$1 {
|
|
|
245
358
|
}
|
|
246
359
|
}
|
|
247
360
|
|
|
361
|
+
/**
|
|
362
|
+
* @description Error thrown when there is an issue with CouchDB indexes
|
|
363
|
+
* @summary Represents an error related to CouchDB index operations
|
|
364
|
+
* @param {string|Error} msg - The error message or Error object
|
|
365
|
+
* @class
|
|
366
|
+
* @category Errors
|
|
367
|
+
* @example
|
|
368
|
+
* // Example of using IndexError
|
|
369
|
+
* try {
|
|
370
|
+
* // Some code that might throw an index error
|
|
371
|
+
* throw new IndexError("Index not found");
|
|
372
|
+
* } catch (error) {
|
|
373
|
+
* if (error instanceof IndexError) {
|
|
374
|
+
* console.error("Index error occurred:", error.message);
|
|
375
|
+
* }
|
|
376
|
+
* }
|
|
377
|
+
*/
|
|
378
|
+
class IndexError extends BaseError {
|
|
379
|
+
constructor(msg) {
|
|
380
|
+
super(IndexError.name, msg, 404);
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
|
|
384
|
+
/**
|
|
385
|
+
* @description Paginator for CouchDB query results
|
|
386
|
+
* @summary Implements pagination for CouchDB queries using bookmarks for efficient navigation through result sets
|
|
387
|
+
* @template M - The model type that extends Model
|
|
388
|
+
* @template R - The result type
|
|
389
|
+
* @param {CouchDBAdapter<any, any, any>} adapter - The CouchDB adapter
|
|
390
|
+
* @param {MangoQuery} query - The Mango query to paginate
|
|
391
|
+
* @param {number} size - The page size
|
|
392
|
+
* @param {Constructor<M>} clazz - The model constructor
|
|
393
|
+
* @class CouchDBPaginator
|
|
394
|
+
* @example
|
|
395
|
+
* // Example of using CouchDBPaginator
|
|
396
|
+
* const adapter = new MyCouchDBAdapter(scope);
|
|
397
|
+
* const query = { selector: { type: "user" } };
|
|
398
|
+
* const paginator = new CouchDBPaginator(adapter, query, 10, User);
|
|
399
|
+
*
|
|
400
|
+
* // Get the first page
|
|
401
|
+
* const page1 = await paginator.page(1);
|
|
402
|
+
*
|
|
403
|
+
* // Get the next page
|
|
404
|
+
* const page2 = await paginator.page(2);
|
|
405
|
+
*/
|
|
248
406
|
class CouchDBPaginator extends Paginator {
|
|
407
|
+
/**
|
|
408
|
+
* @description Gets the total number of pages
|
|
409
|
+
* @summary Not supported in CouchDB - throws an error when accessed
|
|
410
|
+
* @return {number} Never returns as it throws an error
|
|
411
|
+
* @throws {InternalError} Always throws as this functionality is not available in CouchDB
|
|
412
|
+
*/
|
|
249
413
|
get total() {
|
|
250
414
|
throw new InternalError(`The total pages api is not available for couchdb`);
|
|
251
415
|
}
|
|
416
|
+
/**
|
|
417
|
+
* @description Gets the total record count
|
|
418
|
+
* @summary Not supported in CouchDB - throws an error when accessed
|
|
419
|
+
* @return {number} Never returns as it throws an error
|
|
420
|
+
* @throws {InternalError} Always throws as this functionality is not available in CouchDB
|
|
421
|
+
*/
|
|
252
422
|
get count() {
|
|
253
423
|
throw new InternalError(`The record count api is not available for couchdb`);
|
|
254
424
|
}
|
|
255
|
-
|
|
256
|
-
|
|
425
|
+
/**
|
|
426
|
+
* @description Creates a new CouchDBPaginator instance
|
|
427
|
+
* @summary Initializes a paginator for CouchDB query results
|
|
428
|
+
* @param {CouchDBAdapter<any, any, any>} adapter - The CouchDB adapter
|
|
429
|
+
* @param {MangoQuery} query - The Mango query to paginate
|
|
430
|
+
* @param {number} size - The page size
|
|
431
|
+
* @param {Constructor<M>} clazz - The model constructor
|
|
432
|
+
*/
|
|
433
|
+
constructor(adapter, query, size, clazz) {
|
|
434
|
+
super(adapter, query, size, clazz);
|
|
257
435
|
}
|
|
436
|
+
/**
|
|
437
|
+
* @description Prepares a query for pagination
|
|
438
|
+
* @summary Modifies the raw query to include pagination parameters
|
|
439
|
+
* @param {MangoQuery} rawStatement - The original Mango query
|
|
440
|
+
* @return {MangoQuery} The prepared query with pagination parameters
|
|
441
|
+
*/
|
|
258
442
|
prepare(rawStatement) {
|
|
259
443
|
const query = Object.assign({}, rawStatement);
|
|
260
444
|
if (query.limit)
|
|
@@ -262,39 +446,96 @@ class CouchDBPaginator extends Paginator {
|
|
|
262
446
|
query.limit = this.size;
|
|
263
447
|
return query;
|
|
264
448
|
}
|
|
265
|
-
|
|
449
|
+
/**
|
|
450
|
+
* @description Retrieves a specific page of results
|
|
451
|
+
* @summary Executes the query with pagination and processes the results
|
|
452
|
+
* @param {number} [page=1] - The page number to retrieve
|
|
453
|
+
* @return {Promise<R[]>} A promise that resolves to an array of results
|
|
454
|
+
* @throws {PagingError} If trying to access a page other than the first without a bookmark, or if no class is defined
|
|
455
|
+
* @mermaid
|
|
456
|
+
* sequenceDiagram
|
|
457
|
+
* participant Client
|
|
458
|
+
* participant CouchDBPaginator
|
|
459
|
+
* participant Adapter
|
|
460
|
+
* participant CouchDB
|
|
461
|
+
*
|
|
462
|
+
* Client->>CouchDBPaginator: page(pageNumber)
|
|
463
|
+
* Note over CouchDBPaginator: Clone statement
|
|
464
|
+
* CouchDBPaginator->>CouchDBPaginator: validatePage(page)
|
|
465
|
+
*
|
|
466
|
+
* alt page !== 1
|
|
467
|
+
* CouchDBPaginator->>CouchDBPaginator: Check bookmark
|
|
468
|
+
* alt No bookmark
|
|
469
|
+
* CouchDBPaginator-->>Client: Throw PagingError
|
|
470
|
+
* else Has bookmark
|
|
471
|
+
* CouchDBPaginator->>CouchDBPaginator: Add bookmark to statement
|
|
472
|
+
* end
|
|
473
|
+
* end
|
|
474
|
+
*
|
|
475
|
+
* CouchDBPaginator->>Adapter: raw(statement, false)
|
|
476
|
+
* Adapter->>CouchDB: Execute query
|
|
477
|
+
* CouchDB-->>Adapter: Return results
|
|
478
|
+
* Adapter-->>CouchDBPaginator: Return MangoResponse
|
|
479
|
+
*
|
|
480
|
+
* Note over CouchDBPaginator: Process results
|
|
481
|
+
*
|
|
482
|
+
* alt Has warning
|
|
483
|
+
* CouchDBPaginator->>CouchDBPaginator: Log warning
|
|
484
|
+
* end
|
|
485
|
+
*
|
|
486
|
+
* CouchDBPaginator->>CouchDBPaginator: Check for clazz
|
|
487
|
+
*
|
|
488
|
+
* alt No clazz
|
|
489
|
+
* CouchDBPaginator-->>Client: Throw PagingError
|
|
490
|
+
* else Has clazz
|
|
491
|
+
* CouchDBPaginator->>CouchDBPaginator: Find primary key
|
|
492
|
+
*
|
|
493
|
+
* alt Has fields in statement
|
|
494
|
+
* CouchDBPaginator->>CouchDBPaginator: Use docs directly
|
|
495
|
+
* else No fields
|
|
496
|
+
* CouchDBPaginator->>CouchDBPaginator: Process each document
|
|
497
|
+
* loop For each document
|
|
498
|
+
* CouchDBPaginator->>CouchDBPaginator: Extract original ID
|
|
499
|
+
* CouchDBPaginator->>Adapter: revert(doc, clazz, pkDef.id, parsedId)
|
|
500
|
+
* end
|
|
501
|
+
* end
|
|
502
|
+
*
|
|
503
|
+
* CouchDBPaginator->>CouchDBPaginator: Store bookmark
|
|
504
|
+
* CouchDBPaginator->>CouchDBPaginator: Update currentPage
|
|
505
|
+
* CouchDBPaginator-->>Client: Return results
|
|
506
|
+
* end
|
|
507
|
+
*/
|
|
508
|
+
async page(page = 1) {
|
|
266
509
|
const statement = Object.assign({}, this.statement);
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
510
|
+
if (!this._recordCount || !this._totalPages) {
|
|
511
|
+
this._totalPages = this._recordCount = 0;
|
|
512
|
+
const results = await this.adapter.raw({ ...statement, limit: undefined }) || [];
|
|
513
|
+
this._recordCount = results.length;
|
|
514
|
+
if (this._recordCount > 0) {
|
|
515
|
+
const size = statement?.limit || this.size;
|
|
516
|
+
this._totalPages = Math.ceil(this._recordCount / size);
|
|
517
|
+
}
|
|
518
|
+
}
|
|
275
519
|
this.validatePage(page);
|
|
276
520
|
if (page !== 1) {
|
|
277
521
|
if (!this.bookMark)
|
|
278
522
|
throw new PagingError("No bookmark. Did you start in the first page?");
|
|
279
523
|
statement["bookmark"] = this.bookMark;
|
|
280
524
|
}
|
|
281
|
-
const rawResult = await this.adapter.raw(statement, false
|
|
525
|
+
const rawResult = await this.adapter.raw(statement, false);
|
|
282
526
|
const { docs, bookmark, warning } = rawResult;
|
|
283
527
|
if (warning)
|
|
284
528
|
console.warn(warning);
|
|
285
|
-
if (!
|
|
529
|
+
if (!this.clazz)
|
|
286
530
|
throw new PagingError("No statement target defined");
|
|
287
|
-
const pkDef = findPrimaryKey(new
|
|
531
|
+
const pkDef = findPrimaryKey(new this.clazz());
|
|
288
532
|
const results = statement.fields && statement.fields.length
|
|
289
533
|
? docs // has fields means its not full model
|
|
290
534
|
: docs.map((d) => {
|
|
291
535
|
//no fields means we need to revert to saving process
|
|
292
|
-
|
|
293
|
-
throw new PagingError("No statement target defined");
|
|
294
|
-
const pk = pkDef.id;
|
|
295
|
-
const originalId = d._id.split(DefaultSeparator);
|
|
536
|
+
const originalId = d._id.split(CouchDBKeys.SEPARATOR);
|
|
296
537
|
originalId.splice(0, 1); // remove the table name
|
|
297
|
-
return this.adapter.revert(d,
|
|
538
|
+
return this.adapter.revert(d, this.clazz, pkDef.id, Sequence$1.parseValue(pkDef.props.type, originalId.join(CouchDBKeys.SEPARATOR)));
|
|
298
539
|
});
|
|
299
540
|
this.bookMark = bookmark;
|
|
300
541
|
this._currentPage = page;
|
|
@@ -302,300 +543,296 @@ class CouchDBPaginator extends Paginator {
|
|
|
302
543
|
}
|
|
303
544
|
}
|
|
304
545
|
|
|
546
|
+
/**
|
|
547
|
+
* @description Translates core operators to CouchDB Mango operators
|
|
548
|
+
* @summary Converts Decaf.ts core operators to their equivalent CouchDB Mango query operators
|
|
549
|
+
* @param {GroupOperator | Operator} operator - The core operator to translate
|
|
550
|
+
* @return {MangoOperator} The equivalent CouchDB Mango operator
|
|
551
|
+
* @throws {QueryError} If no translation exists for the given operator
|
|
552
|
+
* @function translateOperators
|
|
553
|
+
* @memberOf module:for-couchdb
|
|
554
|
+
* @mermaid
|
|
555
|
+
* sequenceDiagram
|
|
556
|
+
* participant Caller
|
|
557
|
+
* participant translateOperators
|
|
558
|
+
* participant CouchDBOperator
|
|
559
|
+
* participant CouchDBGroupOperator
|
|
560
|
+
*
|
|
561
|
+
* Caller->>translateOperators: operator
|
|
562
|
+
*
|
|
563
|
+
* translateOperators->>CouchDBOperator: Check for match
|
|
564
|
+
* alt Found in CouchDBOperator
|
|
565
|
+
* CouchDBOperator-->>translateOperators: Return matching operator
|
|
566
|
+
* translateOperators-->>Caller: Return MangoOperator
|
|
567
|
+
* else Not found
|
|
568
|
+
* translateOperators->>CouchDBGroupOperator: Check for match
|
|
569
|
+
* alt Found in CouchDBGroupOperator
|
|
570
|
+
* CouchDBGroupOperator-->>translateOperators: Return matching operator
|
|
571
|
+
* translateOperators-->>Caller: Return MangoOperator
|
|
572
|
+
* else Not found
|
|
573
|
+
* translateOperators-->>Caller: Throw QueryError
|
|
574
|
+
* end
|
|
575
|
+
* end
|
|
576
|
+
*/
|
|
577
|
+
function translateOperators(operator) {
|
|
578
|
+
for (const operators of [CouchDBOperator, CouchDBGroupOperator]) {
|
|
579
|
+
const el = Object.keys(operators).find((k) => k === operator);
|
|
580
|
+
if (el)
|
|
581
|
+
return operators[el];
|
|
582
|
+
}
|
|
583
|
+
throw new QueryError(`Could not find adapter translation for operator ${operator}`);
|
|
584
|
+
}
|
|
585
|
+
|
|
586
|
+
/**
|
|
587
|
+
* @description Statement builder for CouchDB Mango queries
|
|
588
|
+
* @summary Provides a fluent interface for building CouchDB Mango queries with type safety
|
|
589
|
+
* @template M - The model type that extends Model
|
|
590
|
+
* @template R - The result type
|
|
591
|
+
* @param adapter - The CouchDB adapter
|
|
592
|
+
* @class CouchDBStatement
|
|
593
|
+
* @example
|
|
594
|
+
* // Example of using CouchDBStatement
|
|
595
|
+
* const adapter = new MyCouchDBAdapter(scope);
|
|
596
|
+
* const statement = new CouchDBStatement<User, User[]>(adapter);
|
|
597
|
+
*
|
|
598
|
+
* // Build a query
|
|
599
|
+
* const users = await statement
|
|
600
|
+
* .from(User)
|
|
601
|
+
* .where(Condition.attribute<User>('age').gt(18))
|
|
602
|
+
* .orderBy('lastName', 'asc')
|
|
603
|
+
* .limit(10)
|
|
604
|
+
* .execute();
|
|
605
|
+
*/
|
|
305
606
|
class CouchDBStatement extends Statement {
|
|
306
607
|
constructor(adapter) {
|
|
307
608
|
super(adapter);
|
|
308
609
|
}
|
|
309
610
|
/**
|
|
310
|
-
* @
|
|
611
|
+
* @description Builds a CouchDB Mango query from the statement
|
|
612
|
+
* @summary Converts the statement's conditions, selectors, and options into a CouchDB Mango query
|
|
613
|
+
* @return {MangoQuery} The built Mango query
|
|
614
|
+
* @throws {Error} If there are invalid query conditions
|
|
615
|
+
* @mermaid
|
|
616
|
+
* sequenceDiagram
|
|
617
|
+
* participant Statement
|
|
618
|
+
* participant Repository
|
|
619
|
+
* participant parseCondition
|
|
620
|
+
*
|
|
621
|
+
* Statement->>Statement: build()
|
|
622
|
+
* Note over Statement: Initialize selectors
|
|
623
|
+
* Statement->>Repository: Get table name
|
|
624
|
+
* Repository-->>Statement: Return table name
|
|
625
|
+
* Statement->>Statement: Create base query
|
|
626
|
+
*
|
|
627
|
+
* alt Has selectSelector
|
|
628
|
+
* Statement->>Statement: Add fields to query
|
|
629
|
+
* end
|
|
630
|
+
*
|
|
631
|
+
* alt Has whereCondition
|
|
632
|
+
* Statement->>Statement: Create combined condition with table
|
|
633
|
+
* Statement->>parseCondition: Parse condition
|
|
634
|
+
* parseCondition-->>Statement: Return parsed condition
|
|
635
|
+
*
|
|
636
|
+
* alt Is group operator
|
|
637
|
+
* alt Is AND operator
|
|
638
|
+
* Statement->>Statement: Flatten nested AND conditions
|
|
639
|
+
* else Is OR operator
|
|
640
|
+
* Statement->>Statement: Combine with table condition
|
|
641
|
+
* else
|
|
642
|
+
* Statement->>Statement: Throw error
|
|
643
|
+
* end
|
|
644
|
+
* else
|
|
645
|
+
* Statement->>Statement: Merge conditions with existing selector
|
|
646
|
+
* end
|
|
647
|
+
* end
|
|
648
|
+
*
|
|
649
|
+
* alt Has orderBySelector
|
|
650
|
+
* Statement->>Statement: Add sort to query
|
|
651
|
+
* Statement->>Statement: Ensure field exists in selector
|
|
652
|
+
* end
|
|
653
|
+
*
|
|
654
|
+
* alt Has limitSelector
|
|
655
|
+
* Statement->>Statement: Set limit
|
|
656
|
+
* else
|
|
657
|
+
* Statement->>Statement: Use default limit
|
|
658
|
+
* end
|
|
659
|
+
*
|
|
660
|
+
* alt Has offsetSelector
|
|
661
|
+
* Statement->>Statement: Set skip
|
|
662
|
+
* end
|
|
663
|
+
*
|
|
664
|
+
* Statement-->>Statement: Return query
|
|
311
665
|
*/
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
666
|
+
build() {
|
|
667
|
+
const selectors = {};
|
|
668
|
+
selectors[CouchDBKeys.TABLE] = {};
|
|
669
|
+
selectors[CouchDBKeys.TABLE] = Repository.table(this.fromSelector);
|
|
670
|
+
const query = { selector: selectors };
|
|
671
|
+
if (this.selectSelector)
|
|
672
|
+
query.fields = this.selectSelector;
|
|
673
|
+
if (this.whereCondition) {
|
|
674
|
+
const condition = this.parseCondition(Condition.and(this.whereCondition, Condition.attribute(CouchDBKeys.TABLE).eq(query.selector[CouchDBKeys.TABLE]))).selector;
|
|
675
|
+
const selectorKeys = Object.keys(condition);
|
|
676
|
+
if (selectorKeys.length === 1 &&
|
|
677
|
+
Object.values(CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1)
|
|
678
|
+
switch (selectorKeys[0]) {
|
|
679
|
+
case CouchDBGroupOperator.AND:
|
|
680
|
+
condition[CouchDBGroupOperator.AND] = [
|
|
681
|
+
...Object.values(condition[CouchDBGroupOperator.AND]).reduce((accum, val) => {
|
|
682
|
+
const keys = Object.keys(val);
|
|
683
|
+
if (keys.length !== 1)
|
|
684
|
+
throw new Error("Too many keys in query selector. should be one");
|
|
685
|
+
const k = keys[0];
|
|
686
|
+
if (k === CouchDBGroupOperator.AND)
|
|
687
|
+
accum.push(...val[k]);
|
|
688
|
+
else
|
|
689
|
+
accum.push(val);
|
|
690
|
+
return accum;
|
|
691
|
+
}, []),
|
|
692
|
+
];
|
|
693
|
+
query.selector = condition;
|
|
694
|
+
break;
|
|
695
|
+
case CouchDBGroupOperator.OR: {
|
|
696
|
+
const s = {};
|
|
697
|
+
s[CouchDBGroupOperator.AND] = [
|
|
698
|
+
condition,
|
|
699
|
+
...Object.entries(query.selector).map(([key, val]) => {
|
|
700
|
+
const result = {};
|
|
701
|
+
result[key] = val;
|
|
702
|
+
return result;
|
|
703
|
+
}),
|
|
704
|
+
];
|
|
705
|
+
query.selector = s;
|
|
706
|
+
break;
|
|
707
|
+
}
|
|
708
|
+
default:
|
|
709
|
+
throw new Error("This should be impossible");
|
|
710
|
+
}
|
|
711
|
+
else {
|
|
712
|
+
Object.entries(condition).forEach(([key, val]) => {
|
|
713
|
+
if (query.selector[key])
|
|
714
|
+
console.warn(`A ${key} query param is about to be overridden: ${query.selector[key]} by ${val}`);
|
|
715
|
+
query.selector[key] = val;
|
|
716
|
+
});
|
|
717
|
+
}
|
|
318
718
|
}
|
|
319
|
-
|
|
320
|
-
|
|
719
|
+
if (this.orderBySelector) {
|
|
720
|
+
query.sort = query.sort || [];
|
|
721
|
+
query.selector = query.selector || {};
|
|
722
|
+
const [selector, value] = this.orderBySelector;
|
|
723
|
+
const rec = {};
|
|
724
|
+
rec[selector] = value;
|
|
725
|
+
query.sort.push(rec);
|
|
726
|
+
if (!query.selector[selector]) {
|
|
727
|
+
query.selector[selector] = {};
|
|
728
|
+
query.selector[selector][CouchDBOperator.BIGGER] =
|
|
729
|
+
null;
|
|
730
|
+
}
|
|
321
731
|
}
|
|
732
|
+
if (this.limitSelector) {
|
|
733
|
+
query.limit = this.limitSelector;
|
|
734
|
+
}
|
|
735
|
+
else {
|
|
736
|
+
console.warn(`No limit selector defined. Using default couchdb limit of ${CouchDBQueryLimit}`);
|
|
737
|
+
query.limit = CouchDBQueryLimit;
|
|
738
|
+
}
|
|
739
|
+
if (this.offsetSelector)
|
|
740
|
+
query.skip = this.offsetSelector;
|
|
741
|
+
return query;
|
|
322
742
|
}
|
|
743
|
+
/**
|
|
744
|
+
* @description Creates a paginator for the statement
|
|
745
|
+
* @summary Builds the query and returns a CouchDBPaginator for paginated results
|
|
746
|
+
* @template R - The result type
|
|
747
|
+
* @param {number} size - The page size
|
|
748
|
+
* @return {Promise<Paginator<M, R, MangoQuery>>} A promise that resolves to a paginator
|
|
749
|
+
* @throws {InternalError} If there's an error building the query
|
|
750
|
+
*/
|
|
323
751
|
async paginate(size) {
|
|
324
752
|
try {
|
|
325
753
|
const query = this.build();
|
|
326
|
-
return new CouchDBPaginator(this, size,
|
|
754
|
+
return new CouchDBPaginator(this.adapter, query, size, this.fromSelector);
|
|
327
755
|
}
|
|
328
756
|
catch (e) {
|
|
329
757
|
throw new InternalError(e);
|
|
330
758
|
}
|
|
331
759
|
}
|
|
760
|
+
/**
|
|
761
|
+
* @description Processes a record from CouchDB
|
|
762
|
+
* @summary Extracts the ID from a CouchDB document and reverts it to a model instance
|
|
763
|
+
* @param {any} r - The raw record from CouchDB
|
|
764
|
+
* @param pkAttr - The primary key attribute of the model
|
|
765
|
+
* @param {"Number" | "BigInt" | undefined} sequenceType - The type of the sequence
|
|
766
|
+
* @return {any} The processed record
|
|
767
|
+
*/
|
|
332
768
|
processRecord(r, pkAttr, sequenceType) {
|
|
333
|
-
if (
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
769
|
+
if (r[CouchDBKeys.ID]) {
|
|
770
|
+
const [, ...keyArgs] = r[CouchDBKeys.ID].split(CouchDBKeys.SEPARATOR);
|
|
771
|
+
const id = keyArgs.join("_");
|
|
772
|
+
return this.adapter.revert(r, this.fromSelector, pkAttr, Sequence$1.parseValue(sequenceType, id));
|
|
773
|
+
}
|
|
774
|
+
return r;
|
|
775
|
+
}
|
|
776
|
+
/**
|
|
777
|
+
* @description Executes a raw Mango query
|
|
778
|
+
* @summary Sends a raw Mango query to CouchDB and processes the results
|
|
779
|
+
* @template R - The result type
|
|
780
|
+
* @param {MangoQuery} rawInput - The raw Mango query to execute
|
|
781
|
+
* @return {Promise<R>} A promise that resolves to the query results
|
|
782
|
+
*/
|
|
783
|
+
async raw(rawInput) {
|
|
784
|
+
const results = await this.adapter.raw(rawInput, true);
|
|
785
|
+
const pkDef = findPrimaryKey(new this.fromSelector());
|
|
346
786
|
const pkAttr = pkDef.id;
|
|
347
787
|
const type = pkDef.props.type;
|
|
348
|
-
if (
|
|
788
|
+
if (!this.selectSelector)
|
|
349
789
|
return results.map((r) => this.processRecord(r, pkAttr, type));
|
|
350
|
-
return
|
|
351
|
-
}
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
// noinspection JSAnnotator
|
|
355
|
-
class CouchDBFromClause extends FromClause {
|
|
356
|
-
constructor(clause) {
|
|
357
|
-
super(clause);
|
|
358
|
-
}
|
|
359
|
-
build(previous) {
|
|
360
|
-
const selectors = {};
|
|
361
|
-
selectors[CouchDBKeys.TABLE] = {};
|
|
362
|
-
selectors[CouchDBKeys.TABLE] =
|
|
363
|
-
typeof this.selector === "string"
|
|
364
|
-
? this.selector
|
|
365
|
-
: Repository.table(this.selector);
|
|
366
|
-
previous.selector = selectors;
|
|
367
|
-
return previous;
|
|
368
|
-
}
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
// noinspection JSAnnotator
|
|
372
|
-
class CouchDBInsertClause extends InsertClause {
|
|
373
|
-
constructor(clause) {
|
|
374
|
-
super(clause);
|
|
375
|
-
}
|
|
376
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
377
|
-
build(query) {
|
|
378
|
-
throw new InternalError("Not supported");
|
|
379
|
-
}
|
|
380
|
-
}
|
|
381
|
-
|
|
382
|
-
class CouchDBWhereClause extends WhereClause {
|
|
383
|
-
constructor(clause) {
|
|
384
|
-
super(clause);
|
|
385
|
-
}
|
|
386
|
-
build(query) {
|
|
387
|
-
const condition = this.adapter.parseCondition(Condition.and(this.condition, Condition.attribute(CouchDBKeys.TABLE).eq(query.selector[CouchDBKeys.TABLE]))).selector;
|
|
388
|
-
const selectorKeys = Object.keys(condition);
|
|
389
|
-
if (selectorKeys.length === 1 &&
|
|
390
|
-
Object.values(CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1)
|
|
391
|
-
switch (selectorKeys[0]) {
|
|
392
|
-
case CouchDBGroupOperator.AND:
|
|
393
|
-
condition[CouchDBGroupOperator.AND] = [
|
|
394
|
-
...Object.values(condition[CouchDBGroupOperator.AND]).reduce((accum, val) => {
|
|
395
|
-
const keys = Object.keys(val);
|
|
396
|
-
if (keys.length !== 1)
|
|
397
|
-
throw new Error("Too many keys in query selector. should be one");
|
|
398
|
-
const k = keys[0];
|
|
399
|
-
if (k === CouchDBGroupOperator.AND)
|
|
400
|
-
accum.push(...val[k]);
|
|
401
|
-
else
|
|
402
|
-
accum.push(val);
|
|
403
|
-
return accum;
|
|
404
|
-
}, []),
|
|
405
|
-
];
|
|
406
|
-
query.selector = condition;
|
|
407
|
-
break;
|
|
408
|
-
case CouchDBGroupOperator.OR: {
|
|
409
|
-
const s = {};
|
|
410
|
-
s[CouchDBGroupOperator.AND] = [
|
|
411
|
-
condition,
|
|
412
|
-
...Object.entries(query.selector).map(([key, val]) => {
|
|
413
|
-
const result = {};
|
|
414
|
-
result[key] = val;
|
|
415
|
-
return result;
|
|
416
|
-
}),
|
|
417
|
-
];
|
|
418
|
-
query.selector = s;
|
|
419
|
-
break;
|
|
420
|
-
}
|
|
421
|
-
default:
|
|
422
|
-
throw new Error("This should be impossible");
|
|
423
|
-
}
|
|
424
|
-
else {
|
|
425
|
-
Object.entries(condition).forEach(([key, val]) => {
|
|
426
|
-
if (query.selector[key])
|
|
427
|
-
console.warn(sf("A {0} query param is about to be overridden: {1} by {2}", key, query.selector[key], val));
|
|
428
|
-
query.selector[key] = val;
|
|
429
|
-
});
|
|
430
|
-
}
|
|
431
|
-
return query;
|
|
432
|
-
}
|
|
433
|
-
}
|
|
434
|
-
|
|
435
|
-
class CouchDBSelectClause extends SelectClause {
|
|
436
|
-
constructor(clause) {
|
|
437
|
-
super(clause);
|
|
438
|
-
}
|
|
439
|
-
build(query) {
|
|
440
|
-
if (!this.selector || this.selector === Const.FULL_RECORD)
|
|
441
|
-
return query;
|
|
442
|
-
query.fields =
|
|
443
|
-
typeof this.selector === "string"
|
|
444
|
-
? [this.selector]
|
|
445
|
-
: this.selector;
|
|
446
|
-
return query;
|
|
447
|
-
}
|
|
448
|
-
}
|
|
449
|
-
|
|
450
|
-
class CouchDBValuesClause extends ValuesClause {
|
|
451
|
-
constructor(clause) {
|
|
452
|
-
super(clause);
|
|
453
|
-
}
|
|
454
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
455
|
-
build(previous) {
|
|
456
|
-
throw new InternalError("Not implemented");
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
|
|
460
|
-
class Factory extends ClauseFactory {
|
|
461
|
-
constructor(adapter) {
|
|
462
|
-
super(adapter);
|
|
463
|
-
}
|
|
464
|
-
from(statement, selector) {
|
|
465
|
-
return new CouchDBFromClause({ statement: statement, selector: selector });
|
|
466
|
-
}
|
|
467
|
-
groupBy(statement, selector) {
|
|
468
|
-
return new (class extends GroupByClause {
|
|
469
|
-
constructor(clause) {
|
|
470
|
-
super(clause);
|
|
471
|
-
}
|
|
472
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
473
|
-
build(query) {
|
|
474
|
-
throw new InternalError("Not implemented");
|
|
475
|
-
}
|
|
476
|
-
})({
|
|
477
|
-
statement: statement,
|
|
478
|
-
selector: selector,
|
|
479
|
-
});
|
|
480
|
-
}
|
|
481
|
-
insert() {
|
|
482
|
-
return new CouchDBInsertClause({
|
|
483
|
-
statement: new CouchDBStatement(this.adapter),
|
|
484
|
-
});
|
|
485
|
-
}
|
|
486
|
-
limit(statement, selector) {
|
|
487
|
-
return new (class extends LimitClause {
|
|
488
|
-
constructor(clause) {
|
|
489
|
-
super(clause);
|
|
490
|
-
}
|
|
491
|
-
build(query) {
|
|
492
|
-
query.limit = this.selector;
|
|
493
|
-
return query;
|
|
494
|
-
}
|
|
495
|
-
})({
|
|
496
|
-
statement: statement,
|
|
497
|
-
selector: selector,
|
|
498
|
-
});
|
|
499
|
-
}
|
|
500
|
-
offset(statement, selector) {
|
|
501
|
-
return new (class extends OffsetClause {
|
|
502
|
-
constructor(clause) {
|
|
503
|
-
super(clause);
|
|
504
|
-
}
|
|
505
|
-
build(query) {
|
|
506
|
-
const skip = parseInt(this.selector);
|
|
507
|
-
if (isNaN(skip))
|
|
508
|
-
throw new QueryError("Failed to parse offset");
|
|
509
|
-
query.skip = skip;
|
|
510
|
-
return query;
|
|
511
|
-
}
|
|
512
|
-
})({
|
|
513
|
-
statement: statement,
|
|
514
|
-
selector: selector,
|
|
515
|
-
});
|
|
516
|
-
}
|
|
517
|
-
orderBy(statement, selector) {
|
|
518
|
-
return new (class extends OrderByClause {
|
|
519
|
-
constructor(clause) {
|
|
520
|
-
super(clause);
|
|
521
|
-
}
|
|
522
|
-
build(query) {
|
|
523
|
-
query.sort = query.sort || [];
|
|
524
|
-
query.selector = query.selector || {};
|
|
525
|
-
this.selector.forEach((s) => {
|
|
526
|
-
const [selector, value] = s;
|
|
527
|
-
const rec = {};
|
|
528
|
-
rec[selector] = value;
|
|
529
|
-
query.sort.push(rec);
|
|
530
|
-
if (!query.selector[selector]) {
|
|
531
|
-
query.selector[selector] = {};
|
|
532
|
-
query.selector[selector][CouchDBOperator.BIGGER] = null;
|
|
533
|
-
}
|
|
534
|
-
// query.fields = query.fields || [];
|
|
535
|
-
// query.fields = [...new Set([...query.fields, selector]).keys()]
|
|
536
|
-
});
|
|
537
|
-
return query;
|
|
538
|
-
}
|
|
539
|
-
})({
|
|
540
|
-
statement: statement,
|
|
541
|
-
selector: selector,
|
|
542
|
-
});
|
|
543
|
-
}
|
|
544
|
-
select(selector) {
|
|
545
|
-
return new CouchDBSelectClause({
|
|
546
|
-
statement: new CouchDBStatement(this.adapter),
|
|
547
|
-
selector: selector,
|
|
548
|
-
});
|
|
549
|
-
}
|
|
550
|
-
values(statement, values) {
|
|
551
|
-
return new CouchDBValuesClause({
|
|
552
|
-
statement: statement,
|
|
553
|
-
values: values,
|
|
554
|
-
});
|
|
555
|
-
}
|
|
556
|
-
where(statement, condition) {
|
|
557
|
-
return new CouchDBWhereClause({
|
|
558
|
-
statement: statement,
|
|
559
|
-
condition: condition,
|
|
560
|
-
});
|
|
561
|
-
}
|
|
562
|
-
}
|
|
563
|
-
|
|
564
|
-
function translateOperators(operator) {
|
|
565
|
-
for (const operators of [CouchDBOperator, CouchDBGroupOperator]) {
|
|
566
|
-
const el = Object.keys(operators).find((k) => k === operator);
|
|
567
|
-
if (el)
|
|
568
|
-
return operators[el];
|
|
569
|
-
}
|
|
570
|
-
throw new QueryError(`Could not find adapter translation for operator ${operator}`);
|
|
571
|
-
}
|
|
572
|
-
|
|
573
|
-
class IndexError extends BaseError {
|
|
574
|
-
constructor(msg) {
|
|
575
|
-
super(IndexError.name, msg);
|
|
576
|
-
}
|
|
577
|
-
}
|
|
578
|
-
|
|
579
|
-
class CouchDBAdapter extends Adapter {
|
|
580
|
-
constructor(scope, flavour) {
|
|
581
|
-
super(scope, flavour);
|
|
582
|
-
[this.create, this.createAll, this.update, this.updateAll].forEach((m) => {
|
|
583
|
-
const name = m.name;
|
|
584
|
-
prefixMethod(this, m, this[name + "Prefix"]);
|
|
585
|
-
});
|
|
586
|
-
}
|
|
587
|
-
get Clauses() {
|
|
588
|
-
if (!this.factory)
|
|
589
|
-
this.factory = new Factory(this);
|
|
590
|
-
return this.factory;
|
|
591
|
-
}
|
|
592
|
-
Query() {
|
|
593
|
-
return super.Query();
|
|
594
|
-
}
|
|
595
|
-
get Statement() {
|
|
596
|
-
return new CouchDBStatement(this);
|
|
790
|
+
return results;
|
|
597
791
|
}
|
|
792
|
+
/**
|
|
793
|
+
* @description Parses a condition into a CouchDB Mango query selector
|
|
794
|
+
* @summary Converts a Condition object into a CouchDB Mango query selector structure
|
|
795
|
+
* @param {Condition<M>} condition - The condition to parse
|
|
796
|
+
* @return {MangoQuery} The Mango query with the parsed condition as its selector
|
|
797
|
+
* @mermaid
|
|
798
|
+
* sequenceDiagram
|
|
799
|
+
* participant Statement
|
|
800
|
+
* participant translateOperators
|
|
801
|
+
* participant merge
|
|
802
|
+
*
|
|
803
|
+
* Statement->>Statement: parseCondition(condition)
|
|
804
|
+
*
|
|
805
|
+
* Note over Statement: Extract condition parts
|
|
806
|
+
*
|
|
807
|
+
* alt Simple comparison operator
|
|
808
|
+
* Statement->>translateOperators: translateOperators(operator)
|
|
809
|
+
* translateOperators-->>Statement: Return CouchDB operator
|
|
810
|
+
* Statement->>Statement: Create selector with attribute and operator
|
|
811
|
+
* else NOT operator
|
|
812
|
+
* Statement->>Statement: parseCondition(attr1)
|
|
813
|
+
* Statement->>translateOperators: translateOperators(Operator.NOT)
|
|
814
|
+
* translateOperators-->>Statement: Return CouchDB NOT operator
|
|
815
|
+
* Statement->>Statement: Create negated selector
|
|
816
|
+
* else AND/OR operator
|
|
817
|
+
* Statement->>Statement: parseCondition(attr1)
|
|
818
|
+
* Statement->>Statement: parseCondition(comparison)
|
|
819
|
+
* Statement->>translateOperators: translateOperators(operator)
|
|
820
|
+
* translateOperators-->>Statement: Return CouchDB group operator
|
|
821
|
+
* Statement->>merge: merge(operator, op1, op2)
|
|
822
|
+
* merge-->>Statement: Return merged selector
|
|
823
|
+
* end
|
|
824
|
+
*
|
|
825
|
+
* Statement-->>Statement: Return query with selector
|
|
826
|
+
*/
|
|
598
827
|
parseCondition(condition) {
|
|
828
|
+
/**
|
|
829
|
+
* @description Merges two selectors with a logical operator
|
|
830
|
+
* @summary Helper function to combine two selectors with a logical operator
|
|
831
|
+
* @param {MangoOperator} op - The operator to use for merging
|
|
832
|
+
* @param {MangoSelector} obj1 - The first selector
|
|
833
|
+
* @param {MangoSelector} obj2 - The second selector
|
|
834
|
+
* @return {MangoQuery} The merged query
|
|
835
|
+
*/
|
|
599
836
|
function merge(op, obj1, obj2) {
|
|
600
837
|
const result = { selector: {} };
|
|
601
838
|
result.selector[op] = [obj1, obj2];
|
|
@@ -620,13 +857,93 @@ class CouchDBAdapter extends Adapter {
|
|
|
620
857
|
}
|
|
621
858
|
return { selector: op };
|
|
622
859
|
}
|
|
860
|
+
}
|
|
861
|
+
|
|
862
|
+
/**
|
|
863
|
+
* @description Abstract adapter for CouchDB database operations
|
|
864
|
+
* @summary Provides a base implementation for CouchDB database operations, including CRUD operations, sequence management, and error handling
|
|
865
|
+
* @template Y - The scope type
|
|
866
|
+
* @template F - The repository flags type
|
|
867
|
+
* @template C - The context type
|
|
868
|
+
* @param {Y} scope - The scope for the adapter
|
|
869
|
+
* @param {string} flavour - The flavour of the adapter
|
|
870
|
+
* @param {string} [alias] - Optional alias for the adapter
|
|
871
|
+
* @class
|
|
872
|
+
* @example
|
|
873
|
+
* // Example of extending CouchDBAdapter
|
|
874
|
+
* class MyCouchDBAdapter extends CouchDBAdapter<MyScope, MyFlags, MyContext> {
|
|
875
|
+
* constructor(scope: MyScope) {
|
|
876
|
+
* super(scope, 'my-couchdb', 'my-alias');
|
|
877
|
+
* }
|
|
878
|
+
*
|
|
879
|
+
* // Implement abstract methods
|
|
880
|
+
* async index<M extends Model>(...models: Constructor<M>[]): Promise<void> {
|
|
881
|
+
* // Implementation
|
|
882
|
+
* }
|
|
883
|
+
*
|
|
884
|
+
* async raw<R>(rawInput: MangoQuery, docsOnly: boolean): Promise<R> {
|
|
885
|
+
* // Implementation
|
|
886
|
+
* }
|
|
887
|
+
*
|
|
888
|
+
* async create(tableName: string, id: string | number, model: Record<string, any>, ...args: any[]): Promise<Record<string, any>> {
|
|
889
|
+
* // Implementation
|
|
890
|
+
* }
|
|
891
|
+
*
|
|
892
|
+
* async read(tableName: string, id: string | number, ...args: any[]): Promise<Record<string, any>> {
|
|
893
|
+
* // Implementation
|
|
894
|
+
* }
|
|
895
|
+
*
|
|
896
|
+
* async update(tableName: string, id: string | number, model: Record<string, any>, ...args: any[]): Promise<Record<string, any>> {
|
|
897
|
+
* // Implementation
|
|
898
|
+
* }
|
|
899
|
+
*
|
|
900
|
+
* async delete(tableName: string, id: string | number, ...args: any[]): Promise<Record<string, any>> {
|
|
901
|
+
* // Implementation
|
|
902
|
+
* }
|
|
903
|
+
* }
|
|
904
|
+
*/
|
|
905
|
+
class CouchDBAdapter extends Adapter {
|
|
906
|
+
constructor(scope, flavour, alias) {
|
|
907
|
+
super(scope, flavour, alias);
|
|
908
|
+
[this.create, this.createAll, this.update, this.updateAll].forEach((m) => {
|
|
909
|
+
const name = m.name;
|
|
910
|
+
prefixMethod(this, m, this[name + "Prefix"]);
|
|
911
|
+
});
|
|
912
|
+
}
|
|
913
|
+
/**
|
|
914
|
+
* @description Creates a new CouchDB statement for querying
|
|
915
|
+
* @summary Factory method that creates a new CouchDBStatement instance for building queries
|
|
916
|
+
* @template M - The model type
|
|
917
|
+
* @return {CouchDBStatement<M, any>} A new CouchDBStatement instance
|
|
918
|
+
*/
|
|
919
|
+
Statement() {
|
|
920
|
+
return new CouchDBStatement(this);
|
|
921
|
+
}
|
|
922
|
+
/**
|
|
923
|
+
* @description Creates a new CouchDB sequence
|
|
924
|
+
* @summary Factory method that creates a new CouchDBSequence instance for managing sequences
|
|
925
|
+
* @param {SequenceOptions} options - The options for the sequence
|
|
926
|
+
* @return {Promise<Sequence>} A promise that resolves to a new Sequence instance
|
|
927
|
+
*/
|
|
623
928
|
async Sequence(options) {
|
|
624
929
|
return new CouchDBSequence(options, this);
|
|
625
930
|
}
|
|
931
|
+
/**
|
|
932
|
+
* @description Initializes the adapter by creating indexes for all managed models
|
|
933
|
+
* @summary Sets up the necessary database indexes for all models managed by this adapter
|
|
934
|
+
* @return {Promise<void>} A promise that resolves when initialization is complete
|
|
935
|
+
*/
|
|
626
936
|
async initialize() {
|
|
627
937
|
const managedModels = Adapter.models(this.flavour);
|
|
628
938
|
return this.index(...managedModels);
|
|
629
939
|
}
|
|
940
|
+
/**
|
|
941
|
+
* @description Assigns metadata to a model
|
|
942
|
+
* @summary Adds revision metadata to a model as a non-enumerable property
|
|
943
|
+
* @param {Record<string, any>} model - The model to assign metadata to
|
|
944
|
+
* @param {string} rev - The revision string to assign
|
|
945
|
+
* @return {Record<string, any>} The model with metadata assigned
|
|
946
|
+
*/
|
|
630
947
|
assignMetadata(model, rev) {
|
|
631
948
|
Object.defineProperty(model, PersistenceKeys.METADATA, {
|
|
632
949
|
enumerable: false,
|
|
@@ -636,6 +953,13 @@ class CouchDBAdapter extends Adapter {
|
|
|
636
953
|
});
|
|
637
954
|
return model;
|
|
638
955
|
}
|
|
956
|
+
/**
|
|
957
|
+
* @description Assigns metadata to multiple models
|
|
958
|
+
* @summary Adds revision metadata to multiple models as non-enumerable properties
|
|
959
|
+
* @param models - The models to assign metadata to
|
|
960
|
+
* @param {string[]} revs - The revision strings to assign
|
|
961
|
+
* @return The models with metadata assigned
|
|
962
|
+
*/
|
|
639
963
|
assignMultipleMetadata(models, revs) {
|
|
640
964
|
models.forEach((m, i) => {
|
|
641
965
|
Repository.setMetadata(m, revs[i]);
|
|
@@ -643,6 +967,14 @@ class CouchDBAdapter extends Adapter {
|
|
|
643
967
|
});
|
|
644
968
|
return models;
|
|
645
969
|
}
|
|
970
|
+
/**
|
|
971
|
+
* @description Prepares a record for creation
|
|
972
|
+
* @summary Adds necessary CouchDB fields to a record before creation
|
|
973
|
+
* @param {string} tableName - The name of the table
|
|
974
|
+
* @param {string|number} id - The ID of the record
|
|
975
|
+
* @param {Record<string, any>} model - The model to prepare
|
|
976
|
+
* @return A tuple containing the tableName, id, and prepared record
|
|
977
|
+
*/
|
|
646
978
|
createPrefix(tableName, id, model) {
|
|
647
979
|
const record = {};
|
|
648
980
|
record[CouchDBKeys.TABLE] = tableName;
|
|
@@ -650,6 +982,15 @@ class CouchDBAdapter extends Adapter {
|
|
|
650
982
|
Object.assign(record, model);
|
|
651
983
|
return [tableName, id, record];
|
|
652
984
|
}
|
|
985
|
+
/**
|
|
986
|
+
* @description Prepares multiple records for creation
|
|
987
|
+
* @summary Adds necessary CouchDB fields to multiple records before creation
|
|
988
|
+
* @param {string} tableName - The name of the table
|
|
989
|
+
* @param {string[]|number[]} ids - The IDs of the records
|
|
990
|
+
* @param models - The models to prepare
|
|
991
|
+
* @return A tuple containing the tableName, ids, and prepared records
|
|
992
|
+
* @throws {InternalError} If ids and models arrays have different lengths
|
|
993
|
+
*/
|
|
653
994
|
createAllPrefix(tableName, ids, models) {
|
|
654
995
|
if (ids.length !== models.length)
|
|
655
996
|
throw new InternalError("Ids and models must have the same length");
|
|
@@ -662,6 +1003,15 @@ class CouchDBAdapter extends Adapter {
|
|
|
662
1003
|
});
|
|
663
1004
|
return [tableName, ids, records];
|
|
664
1005
|
}
|
|
1006
|
+
/**
|
|
1007
|
+
* @description Prepares a record for update
|
|
1008
|
+
* @summary Adds necessary CouchDB fields to a record before update
|
|
1009
|
+
* @param {string} tableName - The name of the table
|
|
1010
|
+
* @param {string|number} id - The ID of the record
|
|
1011
|
+
* @param model - The model to prepare
|
|
1012
|
+
* @return A tuple containing the tableName, id, and prepared record
|
|
1013
|
+
* @throws {InternalError} If no revision number is found in the model
|
|
1014
|
+
*/
|
|
665
1015
|
updatePrefix(tableName, id, model) {
|
|
666
1016
|
const record = {};
|
|
667
1017
|
record[CouchDBKeys.TABLE] = tableName;
|
|
@@ -673,6 +1023,15 @@ class CouchDBAdapter extends Adapter {
|
|
|
673
1023
|
record[CouchDBKeys.REV] = rev;
|
|
674
1024
|
return [tableName, id, record];
|
|
675
1025
|
}
|
|
1026
|
+
/**
|
|
1027
|
+
* @description Prepares multiple records for update
|
|
1028
|
+
* @summary Adds necessary CouchDB fields to multiple records before update
|
|
1029
|
+
* @param {string} tableName - The name of the table
|
|
1030
|
+
* @param {string[]|number[]} ids - The IDs of the records
|
|
1031
|
+
* @param models - The models to prepare
|
|
1032
|
+
* @return A tuple containing the tableName, ids, and prepared records
|
|
1033
|
+
* @throws {InternalError} If ids and models arrays have different lengths or if no revision number is found in a model
|
|
1034
|
+
*/
|
|
676
1035
|
updateAllPrefix(tableName, ids, models) {
|
|
677
1036
|
if (ids.length !== models.length)
|
|
678
1037
|
throw new InternalError("Ids and models must have the same length");
|
|
@@ -689,15 +1048,91 @@ class CouchDBAdapter extends Adapter {
|
|
|
689
1048
|
});
|
|
690
1049
|
return [tableName, ids, records];
|
|
691
1050
|
}
|
|
1051
|
+
/**
|
|
1052
|
+
* @description Generates a CouchDB document ID
|
|
1053
|
+
* @summary Combines the table name and ID to create a CouchDB document ID
|
|
1054
|
+
* @param {string} tableName - The name of the table
|
|
1055
|
+
* @param {string|number} id - The ID of the record
|
|
1056
|
+
* @return {string} The generated CouchDB document ID
|
|
1057
|
+
*/
|
|
692
1058
|
generateId(tableName, id) {
|
|
693
1059
|
return [tableName, id].join(CouchDBKeys.SEPARATOR);
|
|
694
1060
|
}
|
|
1061
|
+
/**
|
|
1062
|
+
* @description Parses an error and converts it to a BaseError
|
|
1063
|
+
* @summary Converts various error types to appropriate BaseError subtypes
|
|
1064
|
+
* @param {Error|string} err - The error to parse
|
|
1065
|
+
* @param {string} [reason] - Optional reason for the error
|
|
1066
|
+
* @return {BaseError} The parsed error as a BaseError
|
|
1067
|
+
*/
|
|
695
1068
|
parseError(err, reason) {
|
|
696
1069
|
return CouchDBAdapter.parseError(err, reason);
|
|
697
1070
|
}
|
|
1071
|
+
/**
|
|
1072
|
+
* @description Checks if an attribute is reserved
|
|
1073
|
+
* @summary Determines if an attribute name is reserved in CouchDB
|
|
1074
|
+
* @param {string} attr - The attribute name to check
|
|
1075
|
+
* @return {boolean} True if the attribute is reserved, false otherwise
|
|
1076
|
+
*/
|
|
698
1077
|
isReserved(attr) {
|
|
699
1078
|
return !!attr.match(reservedAttributes);
|
|
700
1079
|
}
|
|
1080
|
+
/**
|
|
1081
|
+
* @description Static method to parse an error and convert it to a BaseError
|
|
1082
|
+
* @summary Converts various error types to appropriate BaseError subtypes based on error codes and messages
|
|
1083
|
+
* @param {Error|string} err - The error to parse
|
|
1084
|
+
* @param {string} [reason] - Optional reason for the error
|
|
1085
|
+
* @return {BaseError} The parsed error as a BaseError
|
|
1086
|
+
* @mermaid
|
|
1087
|
+
* sequenceDiagram
|
|
1088
|
+
* participant Caller
|
|
1089
|
+
* participant parseError
|
|
1090
|
+
* participant ErrorTypes
|
|
1091
|
+
*
|
|
1092
|
+
* Caller->>parseError: err, reason
|
|
1093
|
+
* Note over parseError: Check if err is already a BaseError
|
|
1094
|
+
* alt err is BaseError
|
|
1095
|
+
* parseError-->>Caller: return err
|
|
1096
|
+
* else err is string
|
|
1097
|
+
* Note over parseError: Extract code from string
|
|
1098
|
+
* alt code matches "already exist|update conflict"
|
|
1099
|
+
* parseError->>ErrorTypes: new ConflictError(code)
|
|
1100
|
+
* ErrorTypes-->>Caller: ConflictError
|
|
1101
|
+
* else code matches "missing|deleted"
|
|
1102
|
+
* parseError->>ErrorTypes: new NotFoundError(code)
|
|
1103
|
+
* ErrorTypes-->>Caller: NotFoundError
|
|
1104
|
+
* end
|
|
1105
|
+
* else err has code property
|
|
1106
|
+
* Note over parseError: Extract code and reason
|
|
1107
|
+
* else err has statusCode property
|
|
1108
|
+
* Note over parseError: Extract code and reason
|
|
1109
|
+
* else
|
|
1110
|
+
* Note over parseError: Use err.message as code
|
|
1111
|
+
* end
|
|
1112
|
+
*
|
|
1113
|
+
* Note over parseError: Switch on code
|
|
1114
|
+
* alt code is 401, 412, or 409
|
|
1115
|
+
* parseError->>ErrorTypes: new ConflictError(reason)
|
|
1116
|
+
* ErrorTypes-->>Caller: ConflictError
|
|
1117
|
+
* else code is 404
|
|
1118
|
+
* parseError->>ErrorTypes: new NotFoundError(reason)
|
|
1119
|
+
* ErrorTypes-->>Caller: NotFoundError
|
|
1120
|
+
* else code is 400
|
|
1121
|
+
* alt code matches "No index exists"
|
|
1122
|
+
* parseError->>ErrorTypes: new IndexError(err)
|
|
1123
|
+
* ErrorTypes-->>Caller: IndexError
|
|
1124
|
+
* else
|
|
1125
|
+
* parseError->>ErrorTypes: new InternalError(err)
|
|
1126
|
+
* ErrorTypes-->>Caller: InternalError
|
|
1127
|
+
* end
|
|
1128
|
+
* else code matches "ECONNREFUSED"
|
|
1129
|
+
* parseError->>ErrorTypes: new ConnectionError(err)
|
|
1130
|
+
* ErrorTypes-->>Caller: ConnectionError
|
|
1131
|
+
* else
|
|
1132
|
+
* parseError->>ErrorTypes: new InternalError(err)
|
|
1133
|
+
* ErrorTypes-->>Caller: InternalError
|
|
1134
|
+
* end
|
|
1135
|
+
*/
|
|
701
1136
|
static parseError(err, reason) {
|
|
702
1137
|
if (err instanceof BaseError)
|
|
703
1138
|
return err;
|
|
@@ -738,10 +1173,104 @@ class CouchDBAdapter extends Adapter {
|
|
|
738
1173
|
}
|
|
739
1174
|
}
|
|
740
1175
|
}
|
|
1176
|
+
__decorate([
|
|
1177
|
+
final(),
|
|
1178
|
+
__metadata("design:type", Function),
|
|
1179
|
+
__metadata("design:paramtypes", []),
|
|
1180
|
+
__metadata("design:returntype", CouchDBStatement)
|
|
1181
|
+
], CouchDBAdapter.prototype, "Statement", null);
|
|
1182
|
+
__decorate([
|
|
1183
|
+
final(),
|
|
1184
|
+
__metadata("design:type", Function),
|
|
1185
|
+
__metadata("design:paramtypes", [Object]),
|
|
1186
|
+
__metadata("design:returntype", Promise)
|
|
1187
|
+
], CouchDBAdapter.prototype, "Sequence", null);
|
|
1188
|
+
__decorate([
|
|
1189
|
+
final(),
|
|
1190
|
+
__metadata("design:type", Function),
|
|
1191
|
+
__metadata("design:paramtypes", [Object, String]),
|
|
1192
|
+
__metadata("design:returntype", Object)
|
|
1193
|
+
], CouchDBAdapter.prototype, "assignMetadata", null);
|
|
1194
|
+
__decorate([
|
|
1195
|
+
final(),
|
|
1196
|
+
__metadata("design:type", Function),
|
|
1197
|
+
__metadata("design:paramtypes", [Array, Array]),
|
|
1198
|
+
__metadata("design:returntype", Array)
|
|
1199
|
+
], CouchDBAdapter.prototype, "assignMultipleMetadata", null);
|
|
1200
|
+
__decorate([
|
|
1201
|
+
final(),
|
|
1202
|
+
__metadata("design:type", Function),
|
|
1203
|
+
__metadata("design:paramtypes", [String, Object, Object]),
|
|
1204
|
+
__metadata("design:returntype", void 0)
|
|
1205
|
+
], CouchDBAdapter.prototype, "createPrefix", null);
|
|
1206
|
+
__decorate([
|
|
1207
|
+
final(),
|
|
1208
|
+
__metadata("design:type", Function),
|
|
1209
|
+
__metadata("design:paramtypes", [String, Array, Array]),
|
|
1210
|
+
__metadata("design:returntype", void 0)
|
|
1211
|
+
], CouchDBAdapter.prototype, "createAllPrefix", null);
|
|
1212
|
+
__decorate([
|
|
1213
|
+
final(),
|
|
1214
|
+
__metadata("design:type", Function),
|
|
1215
|
+
__metadata("design:paramtypes", [String, Object, Object]),
|
|
1216
|
+
__metadata("design:returntype", void 0)
|
|
1217
|
+
], CouchDBAdapter.prototype, "updatePrefix", null);
|
|
1218
|
+
__decorate([
|
|
1219
|
+
final(),
|
|
1220
|
+
__metadata("design:type", Function),
|
|
1221
|
+
__metadata("design:paramtypes", [String, Array, Array]),
|
|
1222
|
+
__metadata("design:returntype", void 0)
|
|
1223
|
+
], CouchDBAdapter.prototype, "updateAllPrefix", null);
|
|
741
1224
|
|
|
1225
|
+
/**
|
|
1226
|
+
* @description Re-authenticates a connection to CouchDB
|
|
1227
|
+
* @summary Refreshes the authentication for a CouchDB connection using the provided credentials
|
|
1228
|
+
* @param {any} con - The CouchDB connection object
|
|
1229
|
+
* @param {string} user - The username for authentication
|
|
1230
|
+
* @param {string} pass - The password for authentication
|
|
1231
|
+
* @return {Promise<any>} A promise that resolves to the authentication result
|
|
1232
|
+
* @function reAuth
|
|
1233
|
+
* @memberOf module:for-couchdb
|
|
1234
|
+
*/
|
|
742
1235
|
async function reAuth(con, user, pass) {
|
|
743
1236
|
return con.auth(user, pass);
|
|
744
1237
|
}
|
|
1238
|
+
/**
|
|
1239
|
+
* @description Wraps a CouchDB database connection with automatic re-authentication
|
|
1240
|
+
* @summary Creates a proxy around a CouchDB database connection that automatically re-authenticates before each operation
|
|
1241
|
+
* @param {any} con - The CouchDB connection object
|
|
1242
|
+
* @param {string} dbName - The name of the database to use
|
|
1243
|
+
* @param {string} user - The username for authentication
|
|
1244
|
+
* @param {string} pass - The password for authentication
|
|
1245
|
+
* @return {any} The wrapped database connection object
|
|
1246
|
+
* @function wrapDocumentScope
|
|
1247
|
+
* @memberOf module:for-couchdb
|
|
1248
|
+
* @mermaid
|
|
1249
|
+
* sequenceDiagram
|
|
1250
|
+
* participant Client
|
|
1251
|
+
* participant wrapDocumentScope
|
|
1252
|
+
* participant DB
|
|
1253
|
+
* participant reAuth
|
|
1254
|
+
*
|
|
1255
|
+
* Client->>wrapDocumentScope: con, dbName, user, pass
|
|
1256
|
+
* wrapDocumentScope->>DB: con.use(dbName)
|
|
1257
|
+
* Note over wrapDocumentScope: Wrap DB methods with re-auth
|
|
1258
|
+
*
|
|
1259
|
+
* loop For each method (insert, get, put, destroy, find)
|
|
1260
|
+
* wrapDocumentScope->>wrapDocumentScope: Store original method
|
|
1261
|
+
* wrapDocumentScope->>wrapDocumentScope: Define new method with re-auth
|
|
1262
|
+
* end
|
|
1263
|
+
*
|
|
1264
|
+
* wrapDocumentScope->>wrapDocumentScope: Add NATIVE property with con value
|
|
1265
|
+
* wrapDocumentScope-->>Client: Return wrapped DB
|
|
1266
|
+
*
|
|
1267
|
+
* Note over Client: Later when client uses DB methods
|
|
1268
|
+
* Client->>DB: Any wrapped method call
|
|
1269
|
+
* DB->>reAuth: Authenticate before operation
|
|
1270
|
+
* reAuth-->>DB: Authentication complete
|
|
1271
|
+
* DB->>DB: Call original method
|
|
1272
|
+
* DB-->>Client: Return result
|
|
1273
|
+
*/
|
|
745
1274
|
function wrapDocumentScope(con, dbName, user, pass) {
|
|
746
1275
|
const db = con.use(dbName);
|
|
747
1276
|
["insert", "get", "put", "destroy", "find"].forEach((k) => {
|
|
@@ -763,10 +1292,30 @@ function wrapDocumentScope(con, dbName, user, pass) {
|
|
|
763
1292
|
});
|
|
764
1293
|
return db;
|
|
765
1294
|
}
|
|
1295
|
+
/**
|
|
1296
|
+
* @description Tests if an attribute name is reserved in CouchDB
|
|
1297
|
+
* @summary Checks if an attribute name starts with an underscore, which indicates it's a reserved attribute in CouchDB
|
|
1298
|
+
* @param {string} attr - The attribute name to test
|
|
1299
|
+
* @return {RegExpMatchArray|null} The match result or null if no match
|
|
1300
|
+
* @function testReservedAttributes
|
|
1301
|
+
* @memberOf module:for-couchdb
|
|
1302
|
+
*/
|
|
766
1303
|
function testReservedAttributes(attr) {
|
|
767
1304
|
const regexp = /^_.*$/g;
|
|
768
1305
|
return attr.match(regexp);
|
|
769
1306
|
}
|
|
1307
|
+
/**
|
|
1308
|
+
* @description Generates a name for a CouchDB index
|
|
1309
|
+
* @summary Creates a standardized name for a CouchDB index based on the table, attribute, compositions, and order
|
|
1310
|
+
* @param {string} attribute - The primary attribute for the index
|
|
1311
|
+
* @param {string} tableName - The name of the table
|
|
1312
|
+
* @param {string[]} [compositions] - Optional additional attributes to include in the index
|
|
1313
|
+
* @param {OrderDirection} [order] - Optional sort order for the index
|
|
1314
|
+
* @param {string} [separator=DefaultSeparator] - The separator to use between parts of the index name
|
|
1315
|
+
* @return {string} The generated index name
|
|
1316
|
+
* @function generateIndexName
|
|
1317
|
+
* @memberOf module:for-couchdb
|
|
1318
|
+
*/
|
|
770
1319
|
function generateIndexName(attribute, tableName, compositions, order, separator = DefaultSeparator) {
|
|
771
1320
|
const attr = [PersistenceKeys.INDEX, tableName, attribute];
|
|
772
1321
|
if (compositions)
|
|
@@ -775,6 +1324,45 @@ function generateIndexName(attribute, tableName, compositions, order, separator
|
|
|
775
1324
|
attr.push(order);
|
|
776
1325
|
return attr.join(separator);
|
|
777
1326
|
}
|
|
1327
|
+
/**
|
|
1328
|
+
* @description Generates a CouchDB index configuration
|
|
1329
|
+
* @summary Creates a complete CreateIndexRequest object for defining a CouchDB index based on specified parameters
|
|
1330
|
+
* @param {string} attribute - The primary attribute for the index
|
|
1331
|
+
* @param {string} tableName - The name of the table
|
|
1332
|
+
* @param {string[]} [compositions] - Optional additional attributes to include in the index
|
|
1333
|
+
* @param {OrderDirection} [order] - Optional sort order for the index
|
|
1334
|
+
* @param {string} [separator=DefaultSeparator] - The separator to use between parts of the index name
|
|
1335
|
+
* @return {CreateIndexRequest} The complete index configuration object
|
|
1336
|
+
* @function generateIndexDoc
|
|
1337
|
+
* @memberOf module:for-couchdb
|
|
1338
|
+
* @mermaid
|
|
1339
|
+
* sequenceDiagram
|
|
1340
|
+
* participant Caller
|
|
1341
|
+
* participant generateIndexDoc
|
|
1342
|
+
* participant generateIndexName
|
|
1343
|
+
*
|
|
1344
|
+
* Caller->>generateIndexDoc: attribute, tableName, compositions, order, separator
|
|
1345
|
+
*
|
|
1346
|
+
* Note over generateIndexDoc: Create partial filter selector
|
|
1347
|
+
* generateIndexDoc->>generateIndexDoc: Set up filter for tableName
|
|
1348
|
+
*
|
|
1349
|
+
* alt order is specified
|
|
1350
|
+
* Note over generateIndexDoc: Create ordered fields array
|
|
1351
|
+
* generateIndexDoc->>generateIndexDoc: Create orderProp for attribute
|
|
1352
|
+
* generateIndexDoc->>generateIndexDoc: Map compositions to ordered props
|
|
1353
|
+
* generateIndexDoc->>generateIndexDoc: Create sortedTable for table field
|
|
1354
|
+
* generateIndexDoc->>generateIndexDoc: Combine all ordered fields
|
|
1355
|
+
* else
|
|
1356
|
+
* Note over generateIndexDoc: Create simple fields array
|
|
1357
|
+
* generateIndexDoc->>generateIndexDoc: Use attribute, compositions, and table as strings
|
|
1358
|
+
* end
|
|
1359
|
+
*
|
|
1360
|
+
* generateIndexDoc->>generateIndexName: Generate index name
|
|
1361
|
+
* generateIndexName-->>generateIndexDoc: Return name
|
|
1362
|
+
*
|
|
1363
|
+
* Note over generateIndexDoc: Create final index request
|
|
1364
|
+
* generateIndexDoc-->>Caller: Return CreateIndexRequest
|
|
1365
|
+
*/
|
|
778
1366
|
function generateIndexDoc(attribute, tableName, compositions, order, separator = DefaultSeparator) {
|
|
779
1367
|
const partialFilterSelector = {};
|
|
780
1368
|
partialFilterSelector[CouchDBKeys.TABLE] = {};
|
|
@@ -807,23 +1395,16 @@ function generateIndexDoc(attribute, tableName, compositions, order, separator =
|
|
|
807
1395
|
}
|
|
808
1396
|
|
|
809
1397
|
/**
|
|
810
|
-
* @
|
|
811
|
-
* @
|
|
812
|
-
* @module
|
|
813
|
-
*/
|
|
814
|
-
/**
|
|
815
|
-
* @summary Namespace summary
|
|
816
|
-
* @description Namespace description
|
|
817
|
-
* @namespace Namespace
|
|
818
|
-
* @memberOf module:ts-workspace
|
|
1398
|
+
* @description CouchDB adapter for Decaf.ts
|
|
1399
|
+
* @summary A TypeScript adapter for CouchDB database operations, providing a seamless integration with the Decaf.ts framework. This module includes classes, interfaces, and utilities for working with CouchDB databases, including support for Mango queries, document operations, and sequence management.
|
|
1400
|
+
* @module for-couchdb
|
|
819
1401
|
*/
|
|
820
1402
|
/**
|
|
821
|
-
* @
|
|
822
|
-
* @
|
|
1403
|
+
* @description Stores the current package version
|
|
1404
|
+
* @summary The version string of the for-couchdb package
|
|
823
1405
|
* @const VERSION
|
|
824
|
-
* @memberOf module:ts-workspace
|
|
825
1406
|
*/
|
|
826
|
-
const VERSION = "0.3.
|
|
1407
|
+
const VERSION = "0.3.2";
|
|
827
1408
|
|
|
828
1409
|
export { CouchDBAdapter, CouchDBKeys, CouchDBSequence, IndexError, Sequence, VERSION, generateIndexDoc, generateIndexName, generateIndexes, reAuth, reservedAttributes, testReservedAttributes, wrapDocumentScope };
|
|
829
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-couchdb.esm.cjs","sources":["../src/constants.ts","../src/query/constants.ts","../src/indexes/generator.ts","../src/model/CouchDBSequence.ts","../src/sequences/utils.ts","../src/sequences/Sequence.ts","../src/query/Paginator.ts","../src/query/Statement.ts","../src/query/FromClause.ts","../src/query/InsertClause.ts","../src/query/WhereClause.ts","../src/query/SelectClause.ts","../src/query/ValuesClause.ts","../src/query/factory.ts","../src/query/translate.ts","../src/errors.ts","../src/adapter.ts","../src/utils.ts","../src/index.ts"],"sourcesContent":["export const reservedAttributes = /^_.*$/g;\n\nexport const CouchDBKeys = {\n  SEPARATOR: \"_\",\n  ID: \"_id\",\n  REV: \"_rev\",\n  DELETED: \"_deleted\",\n  TABLE: \"??table\",\n  SEQUENCE: \"??sequence\",\n  DDOC: \"ddoc\",\n  NATIVE: \"__native\",\n  INDEX: \"index\",\n};\n","import { MangoOperator } from \"../types\";\n\nexport const CouchDBOperator: Record<string, MangoOperator> = {\n  EQUAL: \"$eq\",\n  DIFFERENT: \"$ne\",\n  BIGGER: \"$gt\",\n  BIGGER_EQ: \"$gte\",\n  SMALLER: \"$lt\",\n  SMALLER_EQ: \"$lte\",\n  // BETWEEN = \"BETWEEN\",\n  NOT: \"$not\",\n  IN: \"$in\",\n  // IS = \"IS\",\n  REGEXP: \"$regex\",\n};\n\nexport const CouchDBGroupOperator: Record<string, MangoOperator> = {\n  AND: \"$and\",\n  OR: \"$or\",\n};\n\nexport const CouchDBConst: Record<string, string> = {\n  NULL: \"null\",\n};\n","import {\n  IndexMetadata,\n  OrderDirection,\n  PersistenceKeys,\n  Repository,\n} from \"@decaf-ts/core\";\nimport { CouchDBKeys } from \"../constants\";\nimport { DefaultSeparator } from \"@decaf-ts/db-decorators\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBOperator } from \"../query/constants\";\nimport { CreateIndexRequest } from \"../types\";\n\nfunction generateIndexName(\n  name: string[],\n  direction?: OrderDirection,\n  compositions?: string[],\n  separator = DefaultSeparator\n) {\n  return [\n    ...name.map((n) => (n === CouchDBKeys.TABLE ? \"table\" : n)),\n    ...(compositions || []),\n    ...(direction ? [direction] : []),\n    CouchDBKeys.INDEX,\n  ].join(separator);\n}\n\nexport function generateIndexes<M extends Model>(\n  models: Constructor<M>[]\n): CreateIndexRequest[] {\n  const tableName = generateIndexName([CouchDBKeys.TABLE]);\n  const indexes: Record<string, CreateIndexRequest> = {};\n  indexes[tableName] = {\n    index: {\n      fields: [CouchDBKeys.TABLE],\n    },\n    name: tableName,\n    ddoc: tableName,\n    type: \"json\",\n  };\n\n  models.forEach((m) => {\n    const ind: Record<string, IndexMetadata> = Repository.indexes(m);\n    Object.entries(ind).forEach(([key, value]) => {\n      const k = Object.keys(value)[0];\n      // eslint-disable-next-line prefer-const\n      let { directions, compositions } = (value as any)[k];\n      const tableName = Repository.table(m);\n      compositions = compositions || [];\n\n      function generate(sort?: OrderDirection) {\n        const name = [\n          tableName,\n          key,\n          ...(compositions as []),\n          PersistenceKeys.INDEX,\n        ].join(DefaultSeparator);\n\n        indexes[name] = {\n          index: {\n            fields: [key, ...(compositions as []), CouchDBKeys.TABLE].reduce(\n              (accum: any[], el) => {\n                if (sort) {\n                  const res: any = {};\n                  res[el] = sort;\n                  accum.push(res);\n                } else {\n                  accum.push(el);\n                }\n                return accum;\n              },\n              []\n            ),\n          },\n          name: name,\n          ddoc: name,\n          type: \"json\",\n        };\n        if (!sort) {\n          const tableFilter: Record<string, any> = {};\n          tableFilter[CouchDBKeys.TABLE] = {};\n          tableFilter[CouchDBKeys.TABLE][CouchDBOperator.EQUAL] = tableName;\n          indexes[name].index.partial_filter_selector = tableFilter;\n        }\n      }\n\n      generate();\n      if (directions)\n        (directions as unknown as OrderDirection[]).forEach((d) => generate(d));\n    });\n  });\n  return Object.values(indexes);\n}\n","import type { ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { model, required } from \"@decaf-ts/decorator-validation\";\nimport { BaseModel, pk, index, table } from \"@decaf-ts/core\";\nimport { CouchDBKeys } from \"../constants\";\n\n@table(CouchDBKeys.SEQUENCE)\n@model()\nexport class Sequence extends BaseModel {\n  /**\n   * @summary the Primary key for the DBSequence\n   * @prop name\n   *\n   * @see pk\n   */\n  @pk()\n  id!: string;\n  /**\n   * @summary the current value for the DBSequence\n   * @prop current\n   *\n   * @see required\n   * @see index\n   */\n  @required()\n  @index()\n  current!: string | number;\n\n  constructor(seq?: ModelArg<Sequence>) {\n    super(seq);\n  }\n}\n","import { InternalError } from \"@decaf-ts/db-decorators\";\n\nexport function parseSequenceValue(\n  type: \"Number\" | \"BigInt\" | undefined,\n  value: string | number | bigint\n): string | number | bigint {\n  switch (type) {\n    case \"Number\":\n      return typeof value === \"string\"\n        ? parseInt(value)\n        : typeof value === \"number\"\n          ? value\n          : BigInt(value);\n    case \"BigInt\":\n      return BigInt(value);\n    default:\n      throw new InternalError(\"Should never happen\");\n  }\n}\n","import { sf } from \"@decaf-ts/decorator-validation\";\nimport { Sequence as Seq } from \"../model/CouchDBSequence\";\nimport { InternalError, NotFoundError } from \"@decaf-ts/db-decorators\";\nimport { Adapter, Repository, SequenceOptions } from \"@decaf-ts/core\";\nimport { Sequence } from \"@decaf-ts/core\";\nimport { parseSequenceValue } from \"./utils\";\nimport { MangoQuery } from \"../types\";\nimport { CouchDBRepository } from \"../interfaces\";\n\n/**\n * @summary Abstract implementation of a Sequence\n * @description provides the basic functionality for {@link Sequence}s\n *\n * @param {SequenceOptions} options\n *\n * @class CouchDBSequence\n * @implements Sequence\n *\n * @category Sequences\n */\nexport class CouchDBSequence extends Sequence {\n  protected repo: CouchDBRepository<Seq, any, any, any>;\n\n  constructor(\n    options: SequenceOptions,\n    adapter: Adapter<any, MangoQuery, any, any>\n  ) {\n    super(options);\n    this.repo = Repository.forModel(Seq, adapter.flavour);\n  }\n\n  /**\n   * @summary Retrieves the current value for the sequence\n   * @protected\n   */\n  async current(): Promise<string | number | bigint> {\n    const { name, startWith } = this.options;\n    try {\n      const sequence: Seq = await this.repo.read(name as string);\n      return this.parse(sequence.current as string | number);\n    } catch (e: any) {\n      if (e instanceof NotFoundError) {\n        if (typeof startWith === \"undefined\")\n          throw new InternalError(\n            \"Starting value is not defined for a non existing sequence\"\n          );\n        try {\n          return this.parse(startWith);\n        } catch (e: any) {\n          throw new InternalError(\n            sf(\n              \"Failed to parse initial value for sequence {0}: {1}\",\n              startWith.toString(),\n              e\n            )\n          );\n        }\n      }\n      throw new InternalError(\n        sf(\n          \"Failed to retrieve current value for sequence {0}: {1}\",\n          name as string,\n          e\n        )\n      );\n    }\n  }\n\n  /**\n   * @summary Parses the {@link Sequence} value\n   *\n   * @protected\n   * @param value\n   */\n  private parse(value: string | number | bigint): string | number | bigint {\n    return parseSequenceValue(this.options.type, value);\n  }\n\n  /**\n   * @summary increments the sequence\n   * @description Sequence specific implementation\n   *\n   * @param {string | number | bigint} current\n   * @param count\n   * @protected\n   */\n  private async increment(\n    current: string | number | bigint,\n    count?: number\n  ): Promise<string | number | bigint> {\n    const { type, incrementBy, name } = this.options;\n    let next: string | number | bigint;\n    const toIncrementBy = count || incrementBy;\n    if (toIncrementBy % incrementBy !== 0)\n      throw new InternalError(\n        `Value to increment does not consider the incrementBy setting: ${incrementBy}`\n      );\n    switch (type) {\n      case \"Number\":\n        next = (this.parse(current) as number) + toIncrementBy;\n        break;\n      case \"BigInt\":\n        next = (this.parse(current) as bigint) + BigInt(toIncrementBy);\n        break;\n      default:\n        throw new InternalError(\"Should never happen\");\n    }\n    let seq: Seq;\n    try {\n      seq = await this.repo.update(new Seq({ id: name, current: next }));\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) throw e;\n      seq = await this.repo.create(new Seq({ id: name, current: next }));\n    }\n\n    return seq.current as string | number | bigint;\n  }\n\n  /**\n   * @summary Generates the next value in th sequence\n   * @description calls {@link Sequence#parse} on the current value\n   * followed by {@link Sequence#increment}\n   *\n   */\n  async next(): Promise<number | string | bigint> {\n    const current = await this.current();\n    return this.increment(current);\n  }\n\n  async range(count: number): Promise<(number | string | bigint)[]> {\n    const current = (await this.current()) as number;\n    const incrementBy = this.parse(this.options.incrementBy) as number;\n    const next: string | number | bigint = await this.increment(\n      current,\n      (this.parse(count) as number) * incrementBy\n    );\n    const range: (number | string | bigint)[] = [];\n    for (let i: number = 1; i <= count; i++) {\n      range.push(current + incrementBy * (this.parse(i) as number));\n    }\n    if (range[range.length - 1] !== next)\n      throw new InternalError(\"Miscalculation of range\");\n    return range;\n  }\n}\n","import {\n  Paginator,\n  PagingError,\n  SequenceOptions,\n  Statement,\n} from \"@decaf-ts/core\";\nimport {\n  DefaultSeparator,\n  findPrimaryKey,\n  InternalError,\n} from \"@decaf-ts/db-decorators\";\nimport { parseSequenceValue } from \"../sequences/utils\";\nimport { MangoQuery, MangoResponse } from \"../types\";\n\nexport class CouchDBPaginator<V> extends Paginator<V, MangoQuery> {\n  private bookMark?: string;\n\n  get total(): number {\n    throw new InternalError(`The total pages api is not available for couchdb`);\n  }\n\n  get count(): number {\n    throw new InternalError(\n      `The record count api is not available for couchdb`\n    );\n  }\n\n  constructor(\n    statement: Statement<MangoQuery>,\n    size: number,\n    rawStatement: MangoQuery\n  ) {\n    super(statement, size, rawStatement);\n  }\n\n  protected prepare(rawStatement: MangoQuery): MangoQuery {\n    const query: MangoQuery = Object.assign({}, rawStatement);\n    if (query.limit) this.limit = query.limit;\n\n    query.limit = this.size;\n\n    return query;\n  }\n\n  async page(page: number = 1, ...args: any[]): Promise<V[]> {\n    const statement = Object.assign({}, this.statement);\n    const target = this.stat.getTarget();\n    // if (!this._recordCount || !this._totalPages) {\n    //   // this._recordCount = await this.adapter\n    //   //   .Query()\n    //   //   .count()\n    //   //   .from(target)\n    //   //   .execute<number>();\n    // }\n    this.validatePage(page);\n\n    if (page !== 1) {\n      if (!this.bookMark)\n        throw new PagingError(\"No bookmark. Did you start in the first page?\");\n      statement[\"bookmark\"] = this.bookMark;\n    }\n    const rawResult: MangoResponse<any> = await this.adapter.raw(\n      statement,\n      false,\n      ...args\n    );\n\n    const { docs, bookmark, warning } = rawResult;\n    if (warning) console.warn(warning);\n    if (!target) throw new PagingError(\"No statement target defined\");\n    const pkDef = findPrimaryKey(new target()) as {\n      id: string;\n      props: SequenceOptions;\n    };\n    const results =\n      statement.fields && statement.fields.length\n        ? docs // has fields means its not full model\n        : docs.map((d: any) => {\n            //no fields means we need to revert to saving process\n            if (!target) throw new PagingError(\"No statement target defined\");\n            const pk = pkDef.id;\n            const originalId = d._id.split(DefaultSeparator);\n            originalId.splice(0, 1); // remove the table name\n            return this.adapter.revert(\n              d,\n              target,\n              pk,\n              parseSequenceValue(\n                pkDef.props.type,\n                originalId.join(DefaultSeparator)\n              )\n            );\n          });\n    this.bookMark = bookmark;\n    this._currentPage = page;\n    return results;\n  }\n}\n","import { Adapter, Statement } from \"@decaf-ts/core\";\nimport { findPrimaryKey, InternalError } from \"@decaf-ts/db-decorators\";\nimport { Constructor } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBKeys } from \"../constants\";\nimport { parseSequenceValue } from \"../sequences/utils\";\nimport { Paginator } from \"@decaf-ts/core\";\nimport { CouchDBPaginator } from \"./Paginator\";\nimport { MangoQuery } from \"../types\";\n\nexport class CouchDBStatement<Y> extends Statement<MangoQuery> {\n  constructor(adapter: Adapter<Y, MangoQuery, any, any>) {\n    super(adapter);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  async execute<Y>(): Promise<Y> {\n    try {\n      const query: MangoQuery = this.build();\n      if (!query.limit) query.limit = Number.MAX_SAFE_INTEGER;\n      return this.raw(query);\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  async paginate<R>(size: number): Promise<Paginator<R, MangoQuery>> {\n    try {\n      const query: MangoQuery = this.build();\n      return new CouchDBPaginator(this, size, query);\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  private processRecord(\n    r: any,\n    pkAttr: string,\n    sequenceType: \"Number\" | \"BigInt\" | undefined\n  ) {\n    if (!r[CouchDBKeys.ID])\n      throw new InternalError(\n        `No CouchDB Id definition found. Should not be possible`\n      );\n    const [, ...keyArgs] = r[CouchDBKeys.ID].split(\"_\");\n\n    const id = keyArgs.join(\"_\");\n    return this.adapter.revert(\n      r,\n      this.target as Constructor<any>,\n      pkAttr,\n      parseSequenceValue(sequenceType, id)\n    ) as any;\n  }\n\n  async raw<R>(rawInput: MangoQuery, ...args: any[]): Promise<R> {\n    const results = await this.adapter.raw<R>(rawInput, true, ...args);\n    if (!this.fullRecord) return results;\n    if (!this.target)\n      throw new InternalError(\n        \"No target defined in statement. should never happen\"\n      );\n\n    const pkDef = findPrimaryKey(new this.target() as any);\n    const pkAttr = pkDef.id;\n    const type = pkDef.props.type;\n    if (Array.isArray(results))\n      return results.map((r) =>\n        this.processRecord(r, pkAttr as string, type)\n      ) as R;\n    return this.processRecord(results, pkAttr as string, type) as R;\n  }\n}\n","import { FromClause } from \"@decaf-ts/core\";\nimport { ModelArg, Model, Constructor } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBKeys } from \"../constants\";\nimport { Repository } from \"@decaf-ts/core\";\nimport { MangoQuery } from \"../types\";\n\n// noinspection JSAnnotator\nexport class CouchDBFromClause<M extends Model> extends FromClause<\n  MangoQuery,\n  M\n> {\n  constructor(clause: ModelArg<FromClause<MangoQuery, M>>) {\n    super(clause);\n  }\n\n  build(previous: MangoQuery): MangoQuery {\n    const selectors: any = {};\n    selectors[CouchDBKeys.TABLE] = {};\n    selectors[CouchDBKeys.TABLE] =\n      typeof this.selector === \"string\"\n        ? this.selector\n        : Repository.table(this.selector as Constructor<M>);\n    previous.selector = selectors;\n    return previous;\n  }\n}\n","import { InsertClause } from \"@decaf-ts/core\";\nimport { ModelArg, Model } from \"@decaf-ts/decorator-validation\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { MangoQuery } from \"../types\";\n\n// noinspection JSAnnotator\nexport class CouchDBInsertClause<M extends Model> extends InsertClause<\n  MangoQuery,\n  M\n> {\n  constructor(clause: ModelArg<InsertClause<MangoQuery, M>>) {\n    super(clause);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  build(query: MangoQuery): MangoQuery {\n    throw new InternalError(\"Not supported\");\n  }\n}\n","import { Condition, WhereClause } from \"@decaf-ts/core\";\nimport { ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBGroupOperator } from \"./constants\";\nimport { sf } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBKeys } from \"../constants\";\nimport { MangoOperator, MangoQuery, MangoSelector } from \"../types\";\n\nexport class CouchDBWhereClause extends WhereClause<MangoQuery> {\n  constructor(clause: ModelArg<WhereClause<MangoQuery>>) {\n    super(clause);\n  }\n\n  build(query: MangoQuery): MangoQuery {\n    const condition: MangoSelector = this.adapter.parseCondition(\n      Condition.and(\n        this.condition as Condition,\n        Condition.attribute(CouchDBKeys.TABLE).eq(\n          query.selector[CouchDBKeys.TABLE]\n        )\n      )\n    ).selector;\n\n    const selectorKeys = Object.keys(condition) as MangoOperator[];\n    if (\n      selectorKeys.length === 1 &&\n      Object.values(CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1\n    )\n      switch (selectorKeys[0]) {\n        case CouchDBGroupOperator.AND:\n          condition[CouchDBGroupOperator.AND] = [\n            ...Object.values(\n              condition[CouchDBGroupOperator.AND] as MangoSelector\n            ).reduce((accum: MangoSelector[], val: any) => {\n              const keys = Object.keys(val);\n              if (keys.length !== 1)\n                throw new Error(\n                  \"Too many keys in query selector. should be one\"\n                );\n              const k = keys[0];\n              if (k === CouchDBGroupOperator.AND)\n                accum.push(...(val[k] as any[]));\n              else accum.push(val);\n              return accum;\n            }, []),\n          ];\n          query.selector = condition;\n          break;\n        case CouchDBGroupOperator.OR: {\n          const s: Record<any, any> = {};\n          s[CouchDBGroupOperator.AND] = [\n            condition,\n            ...Object.entries(query.selector).map(([key, val]) => {\n              const result: Record<any, any> = {};\n              result[key] = val;\n              return result;\n            }),\n          ];\n          query.selector = s;\n          break;\n        }\n        default:\n          throw new Error(\"This should be impossible\");\n      }\n    else {\n      Object.entries(condition).forEach(([key, val]) => {\n        if (query.selector[key])\n          console.warn(\n            sf(\n              \"A {0} query param is about to be overridden: {1} by {2}\",\n              key,\n              query.selector[key] as unknown as string,\n              val as unknown as string\n            )\n          );\n        query.selector[key] = val;\n      });\n    }\n\n    return query;\n  }\n}\n","import { Const, SelectClause } from \"@decaf-ts/core\";\nimport { ModelArg, Model } from \"@decaf-ts/decorator-validation\";\nimport { MangoQuery } from \"../types\";\n\nexport class CouchDBSelectClause<M extends Model> extends SelectClause<\n  MangoQuery,\n  M\n> {\n  constructor(clause: ModelArg<SelectClause<MangoQuery, M>>) {\n    super(clause);\n  }\n\n  build(query: MangoQuery): MangoQuery {\n    if (!this.selector || this.selector === Const.FULL_RECORD) return query;\n    query.fields =\n      typeof this.selector === \"string\"\n        ? [this.selector as string]\n        : (this.selector as string[]);\n    return query;\n  }\n}\n","import { ValuesClause } from \"@decaf-ts/core\";\nimport { ModelArg, Model } from \"@decaf-ts/decorator-validation\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { MangoQuery } from \"../types\";\n\nexport class CouchDBValuesClause<M extends Model> extends ValuesClause<\n  MangoQuery,\n  M\n> {\n  constructor(clause: ModelArg<ValuesClause<MangoQuery, M>>) {\n    super(clause);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  build(previous: MangoQuery): MangoQuery {\n    throw new InternalError(\"Not implemented\");\n  }\n}\n","import {\n  ClauseFactory,\n  Condition,\n  FromClause,\n  FromSelector,\n  GroupBySelector,\n  LimitSelector,\n  OffsetSelector,\n  OrderBySelector,\n  QueryError,\n  SelectSelector,\n  Statement,\n} from \"@decaf-ts/core\";\nimport { LimitClause } from \"@decaf-ts/core\";\nimport { SelectClause } from \"@decaf-ts/core\";\nimport { WhereClause } from \"@decaf-ts/core\";\nimport { OffsetClause } from \"@decaf-ts/core\";\nimport { OrderByClause } from \"@decaf-ts/core\";\nimport { GroupByClause } from \"@decaf-ts/core\";\nimport { ValuesClause } from \"@decaf-ts/core\";\nimport { InsertClause } from \"@decaf-ts/core\";\nimport { CouchDBFromClause } from \"./FromClause\";\nimport { ModelArg, Model } from \"@decaf-ts/decorator-validation\";\nimport {\n  Context,\n  InternalError,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { CouchDBInsertClause } from \"./InsertClause\";\nimport { CouchDBStatement } from \"./Statement\";\nimport { CouchDBWhereClause } from \"./WhereClause\";\nimport { CouchDBSelectClause } from \"./SelectClause\";\nimport { CouchDBValuesClause } from \"./ValuesClause\";\nimport { CouchDBOperator } from \"./constants\";\nimport { CouchDBAdapter } from \"../adapter\";\nimport { MangoQuery, MangoSelector } from \"../types\";\n\nexport class Factory<\n  Y,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n> extends ClauseFactory<Y, MangoQuery, CouchDBAdapter<Y, F, C>> {\n  constructor(adapter: CouchDBAdapter<Y, F, C>) {\n    super(adapter);\n  }\n\n  from<M extends Model>(\n    statement: Statement<MangoQuery>,\n    selector: FromSelector<M>\n  ): FromClause<MangoQuery, M> {\n    return new CouchDBFromClause({ statement: statement, selector: selector });\n  }\n\n  groupBy(\n    statement: Statement<MangoQuery>,\n    selector: GroupBySelector\n  ): GroupByClause<MangoQuery> {\n    return new (class extends GroupByClause<MangoQuery> {\n      constructor(clause: ModelArg<GroupByClause<MangoQuery>>) {\n        super(clause);\n      }\n\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      build(query: MangoQuery): MangoQuery {\n        throw new InternalError(\"Not implemented\");\n      }\n    })({\n      statement: statement,\n      selector: selector,\n    });\n  }\n\n  insert<M extends Model>(): InsertClause<MangoQuery, M> {\n    return new CouchDBInsertClause({\n      statement: new CouchDBStatement(this.adapter),\n    });\n  }\n\n  limit(\n    statement: Statement<MangoQuery>,\n    selector: LimitSelector\n  ): LimitClause<MangoQuery> {\n    return new (class extends LimitClause<MangoQuery> {\n      constructor(clause: ModelArg<LimitClause<MangoQuery>>) {\n        super(clause);\n      }\n\n      build(query: MangoQuery): MangoQuery {\n        query.limit = this.selector as number;\n        return query;\n      }\n    })({\n      statement: statement,\n      selector: selector,\n    });\n  }\n\n  offset(\n    statement: Statement<MangoQuery>,\n    selector: OffsetSelector\n  ): OffsetClause<MangoQuery> {\n    return new (class extends OffsetClause<MangoQuery> {\n      constructor(clause: ModelArg<OffsetClause<MangoQuery>>) {\n        super(clause);\n      }\n\n      build(query: MangoQuery): MangoQuery {\n        const skip: number = parseInt(this.selector as unknown as string);\n        if (isNaN(skip)) throw new QueryError(\"Failed to parse offset\");\n        query.skip = skip;\n        return query;\n      }\n    })({\n      statement: statement,\n      selector: selector,\n    });\n  }\n\n  orderBy(\n    statement: Statement<MangoQuery>,\n    selector: OrderBySelector[]\n  ): OrderByClause<MangoQuery> {\n    return new (class extends OrderByClause<MangoQuery> {\n      constructor(clause: ModelArg<OrderByClause<MangoQuery>>) {\n        super(clause);\n      }\n\n      build(query: MangoQuery): MangoQuery {\n        query.sort = query.sort || [];\n        query.selector = query.selector || ({} as MangoSelector);\n        this.selector!.forEach((s) => {\n          const [selector, value] = s;\n          const rec: any = {};\n          rec[selector] = value;\n          (query.sort as any[]).push(rec as any);\n          if (!query.selector[selector]) {\n            query.selector[selector] = {} as MangoSelector;\n            (query.selector[selector] as MangoSelector)[\n              CouchDBOperator.BIGGER\n            ] = null;\n          }\n          // query.fields = query.fields || [];\n          // query.fields = [...new Set([...query.fields, selector]).keys()]\n        });\n        return query;\n      }\n    })({\n      statement: statement,\n      selector: selector,\n    });\n  }\n\n  select<M extends Model>(\n    selector: SelectSelector | undefined\n  ): SelectClause<MangoQuery, M> {\n    return new CouchDBSelectClause({\n      statement: new CouchDBStatement(this.adapter),\n      selector: selector,\n    });\n  }\n\n  values<M extends Model>(\n    statement: Statement<MangoQuery>,\n    values: M[]\n  ): ValuesClause<MangoQuery, M> {\n    return new CouchDBValuesClause<M>({\n      statement: statement,\n      values: values,\n    });\n  }\n\n  where(\n    statement: Statement<MangoQuery>,\n    condition: Condition\n  ): WhereClause<MangoQuery> {\n    return new CouchDBWhereClause({\n      statement: statement,\n      condition: condition,\n    });\n  }\n}\n","import { GroupOperator, Operator } from \"@decaf-ts/core\";\nimport { CouchDBGroupOperator, CouchDBOperator } from \"./constants\";\nimport { QueryError } from \"@decaf-ts/core\";\nimport { MangoOperator } from \"../types\";\n\nexport function translateOperators(\n  operator: GroupOperator | Operator\n): MangoOperator {\n  for (const operators of [CouchDBOperator, CouchDBGroupOperator]) {\n    const el = Object.keys(operators).find((k) => k === operator);\n    if (el) return operators[el];\n  }\n  throw new QueryError(\n    `Could not find adapter translation for operator ${operator}`\n  );\n}\n","import { BaseError } from \"@decaf-ts/db-decorators\";\n\nexport class IndexError extends BaseError {\n  constructor(msg: string | Error) {\n    super(IndexError.name, msg);\n  }\n}\n","import {\n  Adapter,\n  Sequence,\n  SequenceOptions,\n  PersistenceKeys,\n  Operator,\n  GroupOperator,\n  Statement,\n  Query,\n  ClauseFactory,\n  Condition,\n  ConnectionError,\n  Repository,\n} from \"@decaf-ts/core\";\nimport { CouchDBKeys, reservedAttributes } from \"./constants\";\nimport {\n  BaseError,\n  ConflictError,\n  Context,\n  InternalError,\n  NotFoundError,\n  prefixMethod,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport { CouchDBStatement } from \"./query/Statement\";\nimport { Factory } from \"./query\";\nimport { translateOperators } from \"./query/translate\";\nimport { CouchDBSequence } from \"./sequences/Sequence\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { IndexError } from \"./errors\";\nimport { MangoOperator, MangoQuery, MangoSelector } from \"./types\";\n\nexport abstract class CouchDBAdapter<\n  Y,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n> extends Adapter<Y, MangoQuery, F, C> {\n  protected factory?: Factory<Y, F, C>;\n\n  protected constructor(scope: Y, flavour: string) {\n    super(scope, flavour);\n    [this.create, this.createAll, this.update, this.updateAll].forEach((m) => {\n      const name = m.name;\n      prefixMethod(this, m, (this as any)[name + \"Prefix\"]);\n    });\n  }\n\n  get Clauses(): ClauseFactory<Y, MangoQuery, typeof this> {\n    if (!this.factory) this.factory = new Factory(this);\n    return this.factory as ClauseFactory<Y, MangoQuery, typeof this>;\n  }\n\n  Query<M extends Model>(): Query<MangoQuery, M> {\n    return super.Query();\n  }\n\n  get Statement(): Statement<MangoQuery> {\n    return new CouchDBStatement(this);\n  }\n\n  parseCondition(condition: Condition): MangoQuery {\n    function merge(\n      op: MangoOperator,\n      obj1: MangoSelector,\n      obj2: MangoSelector\n    ): MangoQuery {\n      const result: MangoQuery = { selector: {} as MangoSelector };\n      result.selector[op] = [obj1, obj2];\n      return result;\n    }\n\n    const { attr1, operator, comparison } = condition as unknown as {\n      attr1: string | Condition;\n      operator: Operator | GroupOperator;\n      comparison: any;\n    };\n\n    let op: MangoSelector = {} as MangoSelector;\n    if (\n      [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n        operator as GroupOperator\n      ) === -1\n    ) {\n      op[attr1 as string] = {} as MangoSelector;\n      (op[attr1 as string] as MangoSelector)[translateOperators(operator)] =\n        comparison;\n    } else if (operator === Operator.NOT) {\n      op = this.parseCondition(attr1 as Condition).selector as MangoSelector;\n      op[translateOperators(Operator.NOT)] = {} as MangoSelector;\n      (op[translateOperators(Operator.NOT)] as MangoSelector)[\n        (attr1 as unknown as { attr1: string }).attr1\n      ] = comparison;\n    } else {\n      const op1: any = this.parseCondition(attr1 as Condition).selector;\n      const op2: any = this.parseCondition(comparison as Condition).selector;\n      op = merge(translateOperators(operator), op1, op2).selector;\n    }\n\n    return { selector: op };\n  }\n\n  async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new CouchDBSequence(options, this);\n  }\n\n  async initialize(): Promise<void> {\n    const managedModels = Adapter.models(this.flavour);\n    return this.index(...managedModels);\n  }\n\n  protected abstract index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void>;\n\n  abstract raw<V>(rawInput: MangoQuery, process: boolean): Promise<V>;\n\n  protected assignMetadata(\n    model: Record<string, any>,\n    rev: string\n  ): Record<string, any> {\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: rev,\n    });\n    return model;\n  }\n\n  protected assignMultipleMetadata(\n    models: Record<string, any>[],\n    revs: string[]\n  ): Record<string, any>[] {\n    models.forEach((m, i) => {\n      Repository.setMetadata(m as any, revs[i]);\n      return m;\n    });\n    return models;\n  }\n\n  protected createPrefix(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ) {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    return [tableName, id, record];\n  }\n\n  abstract create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>>;\n\n  protected createAllPrefix(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ) {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      Object.assign(record, models[count]);\n      return record;\n    });\n    return [tableName, ids, records];\n  }\n\n  abstract createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]>;\n\n  abstract read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>>;\n\n  abstract readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]>;\n\n  updatePrefix(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ) {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    const rev = model[PersistenceKeys.METADATA];\n    if (!rev)\n      throw new InternalError(\n        `No revision number found for record with id ${id}`\n      );\n    Object.assign(record, model);\n    record[CouchDBKeys.REV] = rev;\n    return [tableName, id, record];\n  }\n\n  abstract update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>>;\n\n  protected updateAllPrefix(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ) {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      const rev = models[count][PersistenceKeys.METADATA];\n      if (!rev)\n        throw new InternalError(\n          `No revision number found for record with id ${id}`\n        );\n      Object.assign(record, models[count]);\n      record[CouchDBKeys.REV] = rev;\n      return record;\n    });\n    return [tableName, ids, records];\n  }\n\n  abstract updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]>;\n\n  abstract delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>>;\n\n  abstract deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]>;\n\n  protected generateId(tableName: string, id: string | number) {\n    return [tableName, id].join(CouchDBKeys.SEPARATOR);\n  }\n\n  parseError(err: Error | string, reason?: string): BaseError {\n    return CouchDBAdapter.parseError(err, reason);\n  }\n\n  protected isReserved(attr: string): boolean {\n    return !!attr.match(reservedAttributes);\n  }\n\n  protected static parseError(err: Error | string, reason?: string): BaseError {\n    if (err instanceof BaseError) return err as any;\n    let code: string = \"\";\n    if (typeof err === \"string\") {\n      code = err;\n      if (code.match(/already exist|update conflict/g))\n        return new ConflictError(code);\n      if (code.match(/missing|deleted/g)) return new NotFoundError(code);\n    } else if ((err as any).code) {\n      code = (err as any).code;\n      reason = reason || err.message;\n    } else if ((err as any).statusCode) {\n      code = (err as any).statusCode;\n      reason = reason || err.message;\n    } else {\n      code = err.message;\n    }\n\n    switch (code.toString()) {\n      case \"401\":\n      case \"412\":\n      case \"409\":\n        return new ConflictError(reason as string);\n      case \"404\":\n        return new NotFoundError(reason as string);\n      case \"400\":\n        if (code.toString().match(/No\\sindex\\sexists/g))\n          return new IndexError(err);\n        return new InternalError(err);\n      default:\n        if (code.toString().match(/ECONNREFUSED/g))\n          return new ConnectionError(err);\n        return new InternalError(err);\n    }\n  }\n}\n","import { OrderDirection, PersistenceKeys } from \"@decaf-ts/core\";\nimport { CouchDBKeys } from \"./constants\";\nimport { DefaultSeparator } from \"@decaf-ts/db-decorators\";\nimport { CouchDBOperator } from \"./query/constants\";\nimport { CreateIndexRequest, MangoSelector, SortOrder } from \"./types\";\n\nexport async function reAuth(con: any, user: string, pass: string) {\n  return con.auth(user, pass);\n}\n\nexport function wrapDocumentScope(\n  con: any,\n  dbName: string,\n  user: string,\n  pass: string\n): any {\n  const db = con.use(dbName);\n  [\"insert\", \"get\", \"put\", \"destroy\", \"find\"].forEach((k) => {\n    const original = (db as Record<string, any>)[k];\n    Object.defineProperty(db, k, {\n      enumerable: false,\n      configurable: true,\n      value: async (...args: any[]) => {\n        await reAuth(con, user, pass);\n        return original.call(db, ...args);\n      },\n    });\n  });\n  Object.defineProperty(db, CouchDBKeys.NATIVE, {\n    enumerable: false,\n    configurable: false,\n    writable: false,\n    value: con,\n  });\n  return db;\n}\n\nexport function testReservedAttributes(attr: string) {\n  const regexp = /^_.*$/g;\n  return attr.match(regexp);\n}\n\nexport function generateIndexName(\n  attribute: string,\n  tableName: string,\n  compositions?: string[],\n  order?: OrderDirection,\n  separator = DefaultSeparator\n): string {\n  const attr = [PersistenceKeys.INDEX, tableName, attribute];\n  if (compositions) attr.push(...compositions);\n  if (order) attr.push(order);\n  return attr.join(separator);\n}\n\nexport function generateIndexDoc(\n  attribute: string,\n  tableName: string,\n  compositions?: string[],\n  order?: OrderDirection,\n  separator = DefaultSeparator\n): CreateIndexRequest {\n  const partialFilterSelector: MangoSelector = {};\n  partialFilterSelector[CouchDBKeys.TABLE] = {} as MangoSelector;\n  (partialFilterSelector[CouchDBKeys.TABLE] as MangoSelector)[\n    CouchDBOperator.EQUAL\n  ] = tableName;\n  let fields: SortOrder[];\n  if (order) {\n    const orderProp: SortOrder = {};\n    orderProp[attribute] = order as \"asc\" | \"desc\";\n    const sortedCompositions: SortOrder[] = (compositions || []).map((c) => {\n      const r: SortOrder = {};\n      r[c] = order as \"asc\" | \"desc\";\n      return r;\n    });\n    const sortedTable: SortOrder = {};\n    sortedTable[CouchDBKeys.TABLE] = order as \"asc\" | \"desc\";\n    fields = [orderProp, ...sortedCompositions, sortedTable];\n  } else {\n    fields = [attribute, ...(compositions || []), CouchDBKeys.TABLE];\n  }\n  const name = generateIndexName(\n    attribute,\n    tableName,\n    compositions,\n    order,\n    separator\n  );\n  return {\n    index: {\n      fields: fields,\n      // partial_filter_selector: partialFilterSelector,\n    },\n    ddoc: [name, CouchDBKeys.DDOC].join(separator),\n    name: name,\n  };\n}\n","export * from \"./indexes\";\nexport * from \"./interfaces\";\nexport * from \"./model\";\nexport * from \"./sequences\";\nexport * from \"./adapter\";\nexport * from \"./constants\";\nexport * from \"./errors\";\nexport * from \"./types\";\nexport * from \"./utils\";\n\n/**\n * @summary Module summary\n * @description Module description\n * @module ts-workspace\n */\n\n/**\n * @summary Namespace summary\n * @description Namespace description\n * @namespace Namespace\n * @memberOf module:ts-workspace\n */\n\n/**\n * @summary stores the current package version\n * @description this is how you should document a constant\n * @const VERSION\n * @memberOf module:ts-workspace\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["generateIndexName","Sequence","Seq"],"mappings":"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"}
|
|
1410
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-couchdb.esm.cjs","sources":["../src/constants.ts","../src/query/constants.ts","../src/indexes/generator.ts","../src/model/CouchDBSequence.ts","../src/sequences/Sequence.ts","../src/errors.ts","../src/query/Paginator.ts","../src/query/translate.ts","../src/query/Statement.ts","../src/adapter.ts","../src/utils.ts","../src/index.ts"],"sourcesContent":["/**\n * @description Regular expression to identify reserved attributes in CouchDB\n * @summary Matches any attribute that starts with an underscore\n * @const reservedAttributes\n * @memberOf module:for-couchdb\n */\nexport const reservedAttributes = /^_.*$/g;\n\n/**\n * @description Key constants used in CouchDB operations\n * @summary Collection of string constants for CouchDB document properties and operations\n * @typedef {Object} CouchDBKeysType\n * @property {string} SEPARATOR - Separator used for combining table name and ID\n * @property {string} ID - CouchDB document ID field\n * @property {string} REV - CouchDB document revision field\n * @property {string} DELETED - CouchDB deleted document marker\n * @property {string} TABLE - Table name marker\n * @property {string} SEQUENCE - Sequence marker\n * @property {string} DDOC - Design document marker\n * @property {string} NATIVE - Native marker\n * @property {string} INDEX - Index marker\n * @memberOf module:for-couchdb\n */\n\n/**\n * @description Key constants used in CouchDB operations\n * @summary Collection of string constants for CouchDB document properties and operations\n * @const CouchDBKeys\n * @type {CouchDBKeysType}\n * @memberOf module:for-couchdb\n */\nexport const CouchDBKeys = {\n  SEPARATOR: \"__\",\n  ID: \"_id\",\n  REV: \"_rev\",\n  DELETED: \"_deleted\",\n  TABLE: \"??table\",\n  SEQUENCE: \"??sequence\",\n  DDOC: \"ddoc\",\n  NATIVE: \"__native\",\n  INDEX: \"index\",\n};\n","import { MangoOperator } from \"../types\";\n\n/**\n * @description Default query limit for CouchDB queries\n * @summary Maximum number of documents to return in a single query\n * @const CouchDBQueryLimit\n * @memberOf module:for-couchdb\n */\nexport const CouchDBQueryLimit = 250;\n\n/**\n * @description Mapping of operator names to CouchDB Mango query operators\n * @summary Constants for CouchDB comparison operators used in Mango queries\n * @typedef {Object} CouchDBOperatorType\n * @property {string} EQUAL - Equality operator ($eq)\n * @property {string} DIFFERENT - Inequality operator ($ne)\n * @property {string} BIGGER - Greater than operator ($gt)\n * @property {string} BIGGER_EQ - Greater than or equal operator ($gte)\n * @property {string} SMALLER - Less than operator ($lt)\n * @property {string} SMALLER_EQ - Less than or equal operator ($lte)\n * @property {string} NOT - Negation operator ($not)\n * @property {string} IN - In array operator ($in)\n * @property {string} REGEXP - Regular expression operator ($regex)\n * @const CouchDBOperator\n * @type {CouchDBOperatorType}\n * @memberOf module:for-couchdb\n */\nexport const CouchDBOperator: Record<string, MangoOperator> = {\n  EQUAL: \"$eq\",\n  DIFFERENT: \"$ne\",\n  BIGGER: \"$gt\",\n  BIGGER_EQ: \"$gte\",\n  SMALLER: \"$lt\",\n  SMALLER_EQ: \"$lte\",\n  // BETWEEN = \"BETWEEN\",\n  NOT: \"$not\",\n  IN: \"$in\",\n  // IS = \"IS\",\n  REGEXP: \"$regex\",\n};\n\n/**\n * @description Mapping of logical operator names to CouchDB Mango query operators\n * @summary Constants for CouchDB logical operators used in Mango queries\n * @typedef {Object} CouchDBGroupOperatorType\n * @property {string} AND - Logical AND operator ($and)\n * @property {string} OR - Logical OR operator ($or)\n * @const CouchDBGroupOperator\n * @type {CouchDBGroupOperatorType}\n * @memberOf module:for-couchdb\n */\nexport const CouchDBGroupOperator: Record<string, MangoOperator> = {\n  AND: \"$and\",\n  OR: \"$or\",\n};\n\n/**\n * @description Special constant values used in CouchDB queries\n * @summary String constants representing special values in CouchDB\n * @typedef {Object} CouchDBConstType\n * @property {string} NULL - String representation of null value\n * @const CouchDBConst\n * @type {CouchDBConstType}\n * @memberOf module:for-couchdb\n */\nexport const CouchDBConst: Record<string, string> = {\n  NULL: \"null\",\n};\n","import {\n  IndexMetadata,\n  OrderDirection,\n  PersistenceKeys,\n  Repository,\n} from \"@decaf-ts/core\";\nimport { CouchDBKeys } from \"../constants\";\nimport { DefaultSeparator } from \"@decaf-ts/db-decorators\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBOperator } from \"../query/constants\";\nimport { CreateIndexRequest } from \"../types\";\n\n/**\n * @description Generates a name for a CouchDB index\n * @summary Creates a standardized name for a CouchDB index by combining name parts, compositions, and direction\n * @param {string[]} name - Array of name parts for the index\n * @param {OrderDirection} [direction] - Optional sort direction for the index\n * @param {string[]} [compositions] - Optional additional attributes to include in the index name\n * @param {string} [separator=DefaultSeparator] - The separator to use between parts of the index name\n * @return {string} The generated index name\n * @memberOf module:for-couchdb\n */\nfunction generateIndexName(\n  name: string[],\n  direction?: OrderDirection,\n  compositions?: string[],\n  separator = DefaultSeparator\n) {\n  return [\n    ...name.map((n) => (n === CouchDBKeys.TABLE ? \"table\" : n)),\n    ...(compositions || []),\n    ...(direction ? [direction] : []),\n    CouchDBKeys.INDEX,\n  ].join(separator);\n}\n\n/**\n * @description Generates CouchDB index configurations for models\n * @summary Creates a set of CouchDB index configurations based on the metadata of the provided models\n * @template M - The model type that extends Model\n * @param models - Array of model constructors to generate indexes for\n * @return {CreateIndexRequest[]} Array of CouchDB index configurations\n * @function generateIndexes\n * @memberOf module:for-couchdb\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant generateIndexes\n *   participant generateIndexName\n *   participant Repository\n *\n *   Caller->>generateIndexes: models\n *\n *   Note over generateIndexes: Create base table index\n *   generateIndexes->>generateIndexName: [CouchDBKeys.TABLE]\n *   generateIndexName-->>generateIndexes: tableName\n *   generateIndexes->>generateIndexes: Create table index config\n *\n *   loop For each model\n *     generateIndexes->>Repository: Get indexes metadata\n *     Repository-->>generateIndexes: index metadata\n *\n *     loop For each index in metadata\n *       Note over generateIndexes: Extract index properties\n *       generateIndexes->>Repository: Get table name\n *       Repository-->>generateIndexes: tableName\n *\n *       Note over generateIndexes: Define nested generate function\n *\n *       generateIndexes->>generateIndexes: Call generate() for default order\n *       Note over generateIndexes: Create index name and config\n *\n *       alt Has directions\n *         loop For each direction\n *           generateIndexes->>generateIndexes: Call generate(direction)\n *           Note over generateIndexes: Create ordered index config\n *         end\n *       end\n *     end\n *   end\n *\n *   generateIndexes-->>Caller: Array of index configurations\n */\nexport function generateIndexes<M extends Model>(\n  models: Constructor<M>[]\n): CreateIndexRequest[] {\n  const tableName = generateIndexName([CouchDBKeys.TABLE]);\n  const indexes: Record<string, CreateIndexRequest> = {};\n  indexes[tableName] = {\n    index: {\n      fields: [CouchDBKeys.TABLE],\n    },\n    name: tableName,\n    ddoc: tableName,\n    type: \"json\",\n  };\n\n  models.forEach((m) => {\n    const ind: Record<string, IndexMetadata> = Repository.indexes(m);\n    Object.entries(ind).forEach(([key, value]) => {\n      const k = Object.keys(value)[0];\n      // eslint-disable-next-line prefer-const\n      let { directions, compositions } = (value as any)[k];\n      const tableName = Repository.table(m);\n      compositions = compositions || [];\n\n      function generate(sort?: OrderDirection) {\n        const name = [\n          tableName,\n          key,\n          ...(compositions as []),\n          PersistenceKeys.INDEX,\n        ].join(DefaultSeparator);\n\n        indexes[name] = {\n          index: {\n            fields: [key, ...(compositions as []), CouchDBKeys.TABLE].reduce(\n              (accum: any[], el) => {\n                if (sort) {\n                  const res: any = {};\n                  res[el] = sort;\n                  accum.push(res);\n                } else {\n                  accum.push(el);\n                }\n                return accum;\n              },\n              []\n            ),\n          },\n          name: name,\n          ddoc: name,\n          type: \"json\",\n        };\n        if (!sort) {\n          const tableFilter: Record<string, any> = {};\n          tableFilter[CouchDBKeys.TABLE] = {};\n          tableFilter[CouchDBKeys.TABLE][CouchDBOperator.EQUAL] = tableName;\n          indexes[name].index.partial_filter_selector = tableFilter;\n        }\n      }\n\n      generate();\n      if (directions)\n        (directions as unknown as OrderDirection[]).forEach((d) => generate(d));\n    });\n  });\n  return Object.values(indexes);\n}\n","import type { ModelArg } from \"@decaf-ts/decorator-validation\";\nimport { model, required } from \"@decaf-ts/decorator-validation\";\nimport { BaseModel, pk, index, table } from \"@decaf-ts/core\";\nimport { CouchDBKeys } from \"../constants\";\n\n/**\n * @description Model for CouchDB sequence records\n * @summary Represents a sequence in CouchDB used for generating sequential IDs\n * @param {ModelArg<Sequence>} [seq] - Optional initialization data for the sequence\n * @class\n * @example\n * // Example of creating and using a Sequence\n * const sequence = new Sequence({ id: 'user-seq', current: 1 });\n * // Increment the sequence\n * sequence.current = Number(sequence.current) + 1;\n */\n@table(CouchDBKeys.SEQUENCE)\n@model()\nexport class Sequence extends BaseModel {\n  /**\n   * @description The unique identifier for the sequence\n   * @summary Primary key for the sequence record\n   */\n  @pk()\n  id!: string;\n\n  /**\n   * @description The current value of the sequence\n   * @summary Current sequence value that can be incremented\n   */\n  @required()\n  @index()\n  current!: string | number;\n\n  constructor(seq?: ModelArg<Sequence>) {\n    super(seq);\n  }\n}\n","import { Sequence as Seq } from \"../model/CouchDBSequence\";\nimport { InternalError, NotFoundError } from \"@decaf-ts/db-decorators\";\nimport { Adapter, Repository, SequenceOptions } from \"@decaf-ts/core\";\nimport { Sequence } from \"@decaf-ts/core\";\nimport { MangoQuery } from \"../types\";\nimport { CouchDBRepository } from \"../interfaces\";\n\n/**\n * @summary Abstract implementation of a Sequence\n * @description provides the basic functionality for {@link Sequence}s\n *\n * @param {SequenceOptions} options\n *\n * @class CouchDBSequence\n * @implements Sequence\n */\nexport class CouchDBSequence extends Sequence {\n  protected repo: CouchDBRepository<Seq, any, any, any>;\n\n  constructor(\n    options: SequenceOptions,\n    adapter: Adapter<any, MangoQuery, any, any>\n  ) {\n    super(options);\n    this.repo = Repository.forModel(Seq, adapter.alias);\n  }\n\n  /**\n   * @summary Retrieves the current value for the sequence\n   * @protected\n   */\n  async current(): Promise<string | number | bigint> {\n    const { name, startWith } = this.options;\n    try {\n      const sequence: Seq = await this.repo.read(name as string);\n      return this.parse(sequence.current as string | number);\n    } catch (e: any) {\n      if (e instanceof NotFoundError) {\n        if (typeof startWith === \"undefined\")\n          throw new InternalError(\n            \"Starting value is not defined for a non existing sequence\"\n          );\n        try {\n          return this.parse(startWith);\n        } catch (e: unknown) {\n          throw new InternalError(\n            `Failed to parse initial value for sequence ${startWith}: ${e}`\n          );\n        }\n      }\n      throw new InternalError(\n        `Failed to retrieve current value for sequence ${name}: ${e}`\n      );\n    }\n  }\n\n  /**\n   * @summary Parses the {@link Sequence} value\n   *\n   * @protected\n   * @param value\n   */\n  private parse(value: string | number | bigint): string | number | bigint {\n    return Sequence.parseValue(this.options.type, value);\n  }\n\n  /**\n   * @summary increments the sequence\n   * @description Sequence specific implementation\n   *\n   * @param {string | number | bigint} current\n   * @param count\n   * @protected\n   */\n  private async increment(\n    current: string | number | bigint,\n    count?: number\n  ): Promise<string | number | bigint> {\n    const { type, incrementBy, name } = this.options;\n    let next: string | number | bigint;\n    const toIncrementBy = count || incrementBy;\n    if (toIncrementBy % incrementBy !== 0)\n      throw new InternalError(\n        `Value to increment does not consider the incrementBy setting: ${incrementBy}`\n      );\n    switch (type) {\n      case \"Number\":\n        next = (this.parse(current) as number) + toIncrementBy;\n        break;\n      case \"BigInt\":\n        next = (this.parse(current) as bigint) + BigInt(toIncrementBy);\n        break;\n      default:\n        throw new InternalError(\"Should never happen\");\n    }\n    let seq: Seq;\n    try {\n      seq = await this.repo.update(new Seq({ id: name, current: next }));\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) throw e;\n      seq = await this.repo.create(new Seq({ id: name, current: next }));\n    }\n\n    return seq.current as string | number | bigint;\n  }\n\n  /**\n   * @summary Generates the next value in th sequence\n   * @description calls {@link Sequence#parse} on the current value\n   * followed by {@link Sequence#increment}\n   *\n   */\n  async next(): Promise<number | string | bigint> {\n    const current = await this.current();\n    return this.increment(current);\n  }\n\n  async range(count: number): Promise<(number | string | bigint)[]> {\n    const current = (await this.current()) as number;\n    const incrementBy = this.parse(this.options.incrementBy) as number;\n    const next: string | number | bigint = await this.increment(\n      current,\n      (this.parse(count) as number) * incrementBy\n    );\n    const range: (number | string | bigint)[] = [];\n    for (let i: number = 1; i <= count; i++) {\n      range.push(current + incrementBy * (this.parse(i) as number));\n    }\n    if (range[range.length - 1] !== next)\n      throw new InternalError(\"Miscalculation of range\");\n    return range;\n  }\n}\n","import { BaseError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Error thrown when there is an issue with CouchDB indexes\n * @summary Represents an error related to CouchDB index operations\n * @param {string|Error} msg - The error message or Error object\n * @class\n * @category Errors\n * @example\n * // Example of using IndexError\n * try {\n *   // Some code that might throw an index error\n *   throw new IndexError(\"Index not found\");\n * } catch (error) {\n *   if (error instanceof IndexError) {\n *     console.error(\"Index error occurred:\", error.message);\n *   }\n * }\n */\nexport class IndexError extends BaseError {\n  constructor(msg: string | Error) {\n    super(IndexError.name, msg, 404);\n  }\n}\n","import { Paginator, PagingError, Sequence } from \"@decaf-ts/core\";\nimport { findPrimaryKey, InternalError } from \"@decaf-ts/db-decorators\";\nimport { MangoQuery, MangoResponse } from \"../types\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBAdapter } from \"../adapter\";\nimport { CouchDBKeys } from \"../constants\";\n\n/**\n * @description Paginator for CouchDB query results\n * @summary Implements pagination for CouchDB queries using bookmarks for efficient navigation through result sets\n * @template M - The model type that extends Model\n * @template R - The result type\n * @param {CouchDBAdapter<any, any, any>} adapter - The CouchDB adapter\n * @param {MangoQuery} query - The Mango query to paginate\n * @param {number} size - The page size\n * @param {Constructor<M>} clazz - The model constructor\n * @class CouchDBPaginator\n * @example\n * // Example of using CouchDBPaginator\n * const adapter = new MyCouchDBAdapter(scope);\n * const query = { selector: { type: \"user\" } };\n * const paginator = new CouchDBPaginator(adapter, query, 10, User);\n *\n * // Get the first page\n * const page1 = await paginator.page(1);\n *\n * // Get the next page\n * const page2 = await paginator.page(2);\n */\nexport class CouchDBPaginator<M extends Model, R> extends Paginator<\n  M,\n  R,\n  MangoQuery\n> {\n  /**\n   * @description Bookmark for CouchDB pagination\n   * @summary Stores the bookmark returned by CouchDB for continuing pagination\n   */\n  private bookMark?: string;\n\n  /**\n   * @description Gets the total number of pages\n   * @summary Not supported in CouchDB - throws an error when accessed\n   * @return {number} Never returns as it throws an error\n   * @throws {InternalError} Always throws as this functionality is not available in CouchDB\n   */\n  override get total(): number {\n    throw new InternalError(`The total pages api is not available for couchdb`);\n  }\n\n  /**\n   * @description Gets the total record count\n   * @summary Not supported in CouchDB - throws an error when accessed\n   * @return {number} Never returns as it throws an error\n   * @throws {InternalError} Always throws as this functionality is not available in CouchDB\n   */\n  override get count(): number {\n    throw new InternalError(\n      `The record count api is not available for couchdb`\n    );\n  }\n\n  /**\n   * @description Creates a new CouchDBPaginator instance\n   * @summary Initializes a paginator for CouchDB query results\n   * @param {CouchDBAdapter<any, any, any>} adapter - The CouchDB adapter\n   * @param {MangoQuery} query - The Mango query to paginate\n   * @param {number} size - The page size\n   * @param {Constructor<M>} clazz - The model constructor\n   */\n  constructor(\n    adapter: CouchDBAdapter<any, any, any>,\n    query: MangoQuery,\n    size: number,\n    clazz: Constructor<M>\n  ) {\n    super(adapter, query, size, clazz);\n  }\n\n  /**\n   * @description Prepares a query for pagination\n   * @summary Modifies the raw query to include pagination parameters\n   * @param {MangoQuery} rawStatement - The original Mango query\n   * @return {MangoQuery} The prepared query with pagination parameters\n   */\n  protected prepare(rawStatement: MangoQuery): MangoQuery {\n    const query: MangoQuery = Object.assign({}, rawStatement);\n    if (query.limit) this.limit = query.limit;\n\n    query.limit = this.size;\n\n    return query;\n  }\n\n  /**\n   * @description Retrieves a specific page of results\n   * @summary Executes the query with pagination and processes the results\n   * @param {number} [page=1] - The page number to retrieve\n   * @return {Promise<R[]>} A promise that resolves to an array of results\n   * @throws {PagingError} If trying to access a page other than the first without a bookmark, or if no class is defined\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant CouchDBPaginator\n   *   participant Adapter\n   *   participant CouchDB\n   *\n   *   Client->>CouchDBPaginator: page(pageNumber)\n   *   Note over CouchDBPaginator: Clone statement\n   *   CouchDBPaginator->>CouchDBPaginator: validatePage(page)\n   *\n   *   alt page !== 1\n   *     CouchDBPaginator->>CouchDBPaginator: Check bookmark\n   *     alt No bookmark\n   *       CouchDBPaginator-->>Client: Throw PagingError\n   *     else Has bookmark\n   *       CouchDBPaginator->>CouchDBPaginator: Add bookmark to statement\n   *     end\n   *   end\n   *\n   *   CouchDBPaginator->>Adapter: raw(statement, false)\n   *   Adapter->>CouchDB: Execute query\n   *   CouchDB-->>Adapter: Return results\n   *   Adapter-->>CouchDBPaginator: Return MangoResponse\n   *\n   *   Note over CouchDBPaginator: Process results\n   *\n   *   alt Has warning\n   *     CouchDBPaginator->>CouchDBPaginator: Log warning\n   *   end\n   *\n   *   CouchDBPaginator->>CouchDBPaginator: Check for clazz\n   *\n   *   alt No clazz\n   *     CouchDBPaginator-->>Client: Throw PagingError\n   *   else Has clazz\n   *     CouchDBPaginator->>CouchDBPaginator: Find primary key\n   *\n   *     alt Has fields in statement\n   *       CouchDBPaginator->>CouchDBPaginator: Use docs directly\n   *     else No fields\n   *       CouchDBPaginator->>CouchDBPaginator: Process each document\n   *       loop For each document\n   *         CouchDBPaginator->>CouchDBPaginator: Extract original ID\n   *         CouchDBPaginator->>Adapter: revert(doc, clazz, pkDef.id, parsedId)\n   *       end\n   *     end\n   *\n   *     CouchDBPaginator->>CouchDBPaginator: Store bookmark\n   *     CouchDBPaginator->>CouchDBPaginator: Update currentPage\n   *     CouchDBPaginator-->>Client: Return results\n   *   end\n   */\n  async page(page: number = 1): Promise<R[]> {\n    const statement = Object.assign({}, this.statement);\n\n   if (!this._recordCount || !this._totalPages) {\n        this._totalPages = this._recordCount = 0;\n        const results: R[] = await this.adapter.raw({ ...statement, limit: undefined }) || [];\n        this._recordCount = results.length;\n        if (this._recordCount > 0) {\n            const size = statement?.limit || this.size;\n            this._totalPages = Math.ceil(this._recordCount / size);\n        }\n    }\n\n    this.validatePage(page);\n\n    if (page !== 1) {\n      if (!this.bookMark)\n        throw new PagingError(\"No bookmark. Did you start in the first page?\");\n      statement[\"bookmark\"] = this.bookMark;\n    }\n    const rawResult: MangoResponse<any> = await this.adapter.raw(\n      statement,\n      false\n    );\n\n    const { docs, bookmark, warning } = rawResult;\n    if (warning) console.warn(warning);\n    if (!this.clazz) throw new PagingError(\"No statement target defined\");\n    const pkDef = findPrimaryKey(new this.clazz());\n    const results =\n      statement.fields && statement.fields.length\n        ? docs // has fields means its not full model\n        : docs.map((d: any) => {\n            //no fields means we need to revert to saving process\n            const originalId = d._id.split(CouchDBKeys.SEPARATOR);\n            originalId.splice(0, 1); // remove the table name\n            return this.adapter.revert(\n              d,\n              this.clazz,\n              pkDef.id,\n              Sequence.parseValue(\n                pkDef.props.type,\n                originalId.join(CouchDBKeys.SEPARATOR)\n              )\n            );\n          });\n    this.bookMark = bookmark;\n    this._currentPage = page;\n    return results;\n  }\n}\n","import { GroupOperator, Operator } from \"@decaf-ts/core\";\nimport { CouchDBGroupOperator, CouchDBOperator } from \"./constants\";\nimport { QueryError } from \"@decaf-ts/core\";\nimport { MangoOperator } from \"../types\";\n\n/**\n * @description Translates core operators to CouchDB Mango operators\n * @summary Converts Decaf.ts core operators to their equivalent CouchDB Mango query operators\n * @param {GroupOperator | Operator} operator - The core operator to translate\n * @return {MangoOperator} The equivalent CouchDB Mango operator\n * @throws {QueryError} If no translation exists for the given operator\n * @function translateOperators\n * @memberOf module:for-couchdb\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant translateOperators\n *   participant CouchDBOperator\n *   participant CouchDBGroupOperator\n *   \n *   Caller->>translateOperators: operator\n *   \n *   translateOperators->>CouchDBOperator: Check for match\n *   alt Found in CouchDBOperator\n *     CouchDBOperator-->>translateOperators: Return matching operator\n *     translateOperators-->>Caller: Return MangoOperator\n *   else Not found\n *     translateOperators->>CouchDBGroupOperator: Check for match\n *     alt Found in CouchDBGroupOperator\n *       CouchDBGroupOperator-->>translateOperators: Return matching operator\n *       translateOperators-->>Caller: Return MangoOperator\n *     else Not found\n *       translateOperators-->>Caller: Throw QueryError\n *     end\n *   end\n */\nexport function translateOperators(\n  operator: GroupOperator | Operator\n): MangoOperator {\n  for (const operators of [CouchDBOperator, CouchDBGroupOperator]) {\n    const el = Object.keys(operators).find((k) => k === operator);\n    if (el) return operators[el];\n  }\n  throw new QueryError(\n    `Could not find adapter translation for operator ${operator}`\n  );\n}\n","import {\n  Condition,\n  GroupOperator,\n  Operator,\n  OrderDirection,\n  Paginator,\n  Repository,\n  Sequence,\n  Statement,\n} from \"@decaf-ts/core\";\nimport { MangoOperator, MangoQuery, MangoSelector } from \"../types\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { CouchDBAdapter } from \"../adapter\";\nimport { translateOperators } from \"./translate\";\nimport { CouchDBKeys } from \"../constants\";\nimport {\n  CouchDBGroupOperator,\n  CouchDBOperator,\n  CouchDBQueryLimit,\n} from \"./constants\";\nimport { CouchDBPaginator } from \"./Paginator\";\nimport { findPrimaryKey, InternalError } from \"@decaf-ts/db-decorators\";\n\n/**\n * @description Statement builder for CouchDB Mango queries\n * @summary Provides a fluent interface for building CouchDB Mango queries with type safety\n * @template M - The model type that extends Model\n * @template R - The result type\n * @param adapter - The CouchDB adapter\n * @class CouchDBStatement\n * @example\n * // Example of using CouchDBStatement\n * const adapter = new MyCouchDBAdapter(scope);\n * const statement = new CouchDBStatement<User, User[]>(adapter);\n *\n * // Build a query\n * const users = await statement\n *   .from(User)\n *   .where(Condition.attribute<User>('age').gt(18))\n *   .orderBy('lastName', 'asc')\n *   .limit(10)\n *   .execute();\n */\nexport class CouchDBStatement<M extends Model, R> extends Statement<\n  MangoQuery,\n  M,\n  R\n> {\n  constructor(adapter: CouchDBAdapter<any, any, any>) {\n    super(adapter);\n  }\n\n  /**\n   * @description Builds a CouchDB Mango query from the statement\n   * @summary Converts the statement's conditions, selectors, and options into a CouchDB Mango query\n   * @return {MangoQuery} The built Mango query\n   * @throws {Error} If there are invalid query conditions\n   * @mermaid\n   * sequenceDiagram\n   *   participant Statement\n   *   participant Repository\n   *   participant parseCondition\n   *\n   *   Statement->>Statement: build()\n   *   Note over Statement: Initialize selectors\n   *   Statement->>Repository: Get table name\n   *   Repository-->>Statement: Return table name\n   *   Statement->>Statement: Create base query\n   *\n   *   alt Has selectSelector\n   *     Statement->>Statement: Add fields to query\n   *   end\n   *\n   *   alt Has whereCondition\n   *     Statement->>Statement: Create combined condition with table\n   *     Statement->>parseCondition: Parse condition\n   *     parseCondition-->>Statement: Return parsed condition\n   *\n   *     alt Is group operator\n   *       alt Is AND operator\n   *         Statement->>Statement: Flatten nested AND conditions\n   *       else Is OR operator\n   *         Statement->>Statement: Combine with table condition\n   *       else\n   *         Statement->>Statement: Throw error\n   *       end\n   *     else\n   *       Statement->>Statement: Merge conditions with existing selector\n   *     end\n   *   end\n   *\n   *   alt Has orderBySelector\n   *     Statement->>Statement: Add sort to query\n   *     Statement->>Statement: Ensure field exists in selector\n   *   end\n   *\n   *   alt Has limitSelector\n   *     Statement->>Statement: Set limit\n   *   else\n   *     Statement->>Statement: Use default limit\n   *   end\n   *\n   *   alt Has offsetSelector\n   *     Statement->>Statement: Set skip\n   *   end\n   *\n   *   Statement-->>Statement: Return query\n   */\n  protected build(): MangoQuery {\n    const selectors: MangoSelector = {};\n    selectors[CouchDBKeys.TABLE] = {};\n    selectors[CouchDBKeys.TABLE] = Repository.table(this.fromSelector);\n    const query: MangoQuery = { selector: selectors };\n    if (this.selectSelector) query.fields = this.selectSelector as string[];\n\n    if (this.whereCondition) {\n      const condition: MangoSelector = this.parseCondition(\n        Condition.and(\n          this.whereCondition,\n          Condition.attribute<M>(CouchDBKeys.TABLE as keyof M).eq(\n            query.selector[CouchDBKeys.TABLE]\n          )\n        )\n      ).selector;\n      const selectorKeys = Object.keys(condition) as MangoOperator[];\n      if (\n        selectorKeys.length === 1 &&\n        Object.values(CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1\n      )\n        switch (selectorKeys[0]) {\n          case CouchDBGroupOperator.AND:\n            condition[CouchDBGroupOperator.AND] = [\n              ...Object.values(\n                condition[CouchDBGroupOperator.AND] as MangoSelector\n              ).reduce((accum: MangoSelector[], val: any) => {\n                const keys = Object.keys(val);\n                if (keys.length !== 1)\n                  throw new Error(\n                    \"Too many keys in query selector. should be one\"\n                  );\n                const k = keys[0];\n                if (k === CouchDBGroupOperator.AND)\n                  accum.push(...(val[k] as any[]));\n                else accum.push(val);\n                return accum;\n              }, []),\n            ];\n            query.selector = condition;\n            break;\n          case CouchDBGroupOperator.OR: {\n            const s: Record<any, any> = {};\n            s[CouchDBGroupOperator.AND] = [\n              condition,\n              ...Object.entries(query.selector).map(([key, val]) => {\n                const result: Record<any, any> = {};\n                result[key] = val;\n                return result;\n              }),\n            ];\n            query.selector = s;\n            break;\n          }\n          default:\n            throw new Error(\"This should be impossible\");\n        }\n      else {\n        Object.entries(condition).forEach(([key, val]) => {\n          if (query.selector[key])\n            console.warn(\n              `A ${key} query param is about to be overridden: ${query.selector[key]} by ${val}`\n            );\n          query.selector[key] = val;\n        });\n      }\n    }\n\n    if (this.orderBySelector) {\n      query.sort = query.sort || [];\n      query.selector = query.selector || ({} as MangoSelector);\n      const [selector, value] = this.orderBySelector as [\n        string,\n        OrderDirection,\n      ];\n      const rec: any = {};\n      rec[selector] = value;\n      (query.sort as any[]).push(rec as any);\n      if (!query.selector[selector]) {\n        query.selector[selector] = {} as MangoSelector;\n        (query.selector[selector] as MangoSelector)[CouchDBOperator.BIGGER] =\n          null;\n      }\n    }\n\n    if (this.limitSelector) {\n      query.limit = this.limitSelector;\n    } else {\n      console.warn(\n        `No limit selector defined. Using default couchdb limit of ${CouchDBQueryLimit}`\n      );\n      query.limit = CouchDBQueryLimit;\n    }\n\n    if (this.offsetSelector) query.skip = this.offsetSelector;\n\n    return query;\n  }\n\n  /**\n   * @description Creates a paginator for the statement\n   * @summary Builds the query and returns a CouchDBPaginator for paginated results\n   * @template R - The result type\n   * @param {number} size - The page size\n   * @return {Promise<Paginator<M, R, MangoQuery>>} A promise that resolves to a paginator\n   * @throws {InternalError} If there's an error building the query\n   */\n  async paginate<R>(size: number): Promise<Paginator<M, R, MangoQuery>> {\n    try {\n      const query: MangoQuery = this.build();\n      return new CouchDBPaginator(\n        this.adapter as any,\n        query,\n        size,\n        this.fromSelector\n      );\n    } catch (e: any) {\n      throw new InternalError(e);\n    }\n  }\n\n  /**\n   * @description Processes a record from CouchDB\n   * @summary Extracts the ID from a CouchDB document and reverts it to a model instance\n   * @param {any} r - The raw record from CouchDB\n   * @param pkAttr - The primary key attribute of the model\n   * @param {\"Number\" | \"BigInt\" | undefined} sequenceType - The type of the sequence\n   * @return {any} The processed record\n   */\n  private processRecord(\n    r: any,\n    pkAttr: keyof M,\n    sequenceType: \"Number\" | \"BigInt\" | undefined\n  ) {\n    if (r[CouchDBKeys.ID]) {\n      const [, ...keyArgs] = r[CouchDBKeys.ID].split(CouchDBKeys.SEPARATOR);\n\n      const id = keyArgs.join(\"_\");\n      return this.adapter.revert(\n        r,\n        this.fromSelector,\n        pkAttr,\n        Sequence.parseValue(sequenceType, id)\n      );\n    }\n    return r;\n  }\n\n  /**\n   * @description Executes a raw Mango query\n   * @summary Sends a raw Mango query to CouchDB and processes the results\n   * @template R - The result type\n   * @param {MangoQuery} rawInput - The raw Mango query to execute\n   * @return {Promise<R>} A promise that resolves to the query results\n   */\n  override async raw<R>(rawInput: MangoQuery): Promise<R> {\n    const results: any[] = await this.adapter.raw(rawInput, true);\n\n    const pkDef = findPrimaryKey(new this.fromSelector());\n    const pkAttr = pkDef.id;\n    const type = pkDef.props.type;\n\n    if (!this.selectSelector)\n      return results.map((r) => this.processRecord(r, pkAttr, type)) as R;\n    return results as R;\n  }\n\n  /**\n   * @description Parses a condition into a CouchDB Mango query selector\n   * @summary Converts a Condition object into a CouchDB Mango query selector structure\n   * @param {Condition<M>} condition - The condition to parse\n   * @return {MangoQuery} The Mango query with the parsed condition as its selector\n   * @mermaid\n   * sequenceDiagram\n   *   participant Statement\n   *   participant translateOperators\n   *   participant merge\n   *\n   *   Statement->>Statement: parseCondition(condition)\n   *\n   *   Note over Statement: Extract condition parts\n   *\n   *   alt Simple comparison operator\n   *     Statement->>translateOperators: translateOperators(operator)\n   *     translateOperators-->>Statement: Return CouchDB operator\n   *     Statement->>Statement: Create selector with attribute and operator\n   *   else NOT operator\n   *     Statement->>Statement: parseCondition(attr1)\n   *     Statement->>translateOperators: translateOperators(Operator.NOT)\n   *     translateOperators-->>Statement: Return CouchDB NOT operator\n   *     Statement->>Statement: Create negated selector\n   *   else AND/OR operator\n   *     Statement->>Statement: parseCondition(attr1)\n   *     Statement->>Statement: parseCondition(comparison)\n   *     Statement->>translateOperators: translateOperators(operator)\n   *     translateOperators-->>Statement: Return CouchDB group operator\n   *     Statement->>merge: merge(operator, op1, op2)\n   *     merge-->>Statement: Return merged selector\n   *   end\n   *\n   *   Statement-->>Statement: Return query with selector\n   */\n  protected parseCondition(condition: Condition<M>): MangoQuery {\n    /**\n     * @description Merges two selectors with a logical operator\n     * @summary Helper function to combine two selectors with a logical operator\n     * @param {MangoOperator} op - The operator to use for merging\n     * @param {MangoSelector} obj1 - The first selector\n     * @param {MangoSelector} obj2 - The second selector\n     * @return {MangoQuery} The merged query\n     */\n    function merge(\n      op: MangoOperator,\n      obj1: MangoSelector,\n      obj2: MangoSelector\n    ): MangoQuery {\n      const result: MangoQuery = { selector: {} as MangoSelector };\n      result.selector[op] = [obj1, obj2];\n      return result;\n    }\n\n    const { attr1, operator, comparison } = condition as unknown as {\n      attr1: string | Condition<M>;\n      operator: Operator | GroupOperator;\n      comparison: any;\n    };\n\n    let op: MangoSelector = {} as MangoSelector;\n    if (\n      [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n        operator as GroupOperator\n      ) === -1\n    ) {\n      op[attr1 as string] = {} as MangoSelector;\n      (op[attr1 as string] as MangoSelector)[translateOperators(operator)] =\n        comparison;\n    } else if (operator === Operator.NOT) {\n      op = this.parseCondition(attr1 as Condition<M>).selector as MangoSelector;\n      op[translateOperators(Operator.NOT)] = {} as MangoSelector;\n      (op[translateOperators(Operator.NOT)] as MangoSelector)[\n        (attr1 as unknown as { attr1: string }).attr1\n      ] = comparison;\n    } else {\n      const op1: any = this.parseCondition(attr1 as Condition<M>).selector;\n      const op2: any = this.parseCondition(comparison as Condition<M>).selector;\n      op = merge(translateOperators(operator), op1, op2).selector;\n    }\n\n    return { selector: op };\n  }\n}\n","import {\n  Adapter,\n  Sequence,\n  type SequenceOptions,\n  PersistenceKeys,\n  ConnectionError,\n  Repository,\n} from \"@decaf-ts/core\";\nimport { CouchDBKeys, reservedAttributes } from \"./constants\";\nimport {\n  BaseError,\n  ConflictError,\n  Context,\n  InternalError,\n  NotFoundError,\n  prefixMethod,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\n\nimport { CouchDBSequence } from \"./sequences/Sequence\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { IndexError } from \"./errors\";\nimport { MangoQuery } from \"./types\";\nimport { CouchDBStatement } from \"./query\";\nimport { final } from \"@decaf-ts/core\";\n\n/**\n * @description Abstract adapter for CouchDB database operations\n * @summary Provides a base implementation for CouchDB database operations, including CRUD operations, sequence management, and error handling\n * @template Y - The scope type\n * @template F - The repository flags type\n * @template C - The context type\n * @param {Y} scope - The scope for the adapter\n * @param {string} flavour - The flavour of the adapter\n * @param {string} [alias] - Optional alias for the adapter\n * @class\n * @example\n * // Example of extending CouchDBAdapter\n * class MyCouchDBAdapter extends CouchDBAdapter<MyScope, MyFlags, MyContext> {\n *   constructor(scope: MyScope) {\n *     super(scope, 'my-couchdb', 'my-alias');\n *   }\n *\n *   // Implement abstract methods\n *   async index<M extends Model>(...models: Constructor<M>[]): Promise<void> {\n *     // Implementation\n *   }\n *\n *   async raw<R>(rawInput: MangoQuery, docsOnly: boolean): Promise<R> {\n *     // Implementation\n *   }\n *\n *   async create(tableName: string, id: string | number, model: Record<string, any>, ...args: any[]): Promise<Record<string, any>> {\n *     // Implementation\n *   }\n *\n *   async read(tableName: string, id: string | number, ...args: any[]): Promise<Record<string, any>> {\n *     // Implementation\n *   }\n *\n *   async update(tableName: string, id: string | number, model: Record<string, any>, ...args: any[]): Promise<Record<string, any>> {\n *     // Implementation\n *   }\n *\n *   async delete(tableName: string, id: string | number, ...args: any[]): Promise<Record<string, any>> {\n *     // Implementation\n *   }\n * }\n */\nexport abstract class CouchDBAdapter<\n  Y,\n  F extends RepositoryFlags,\n  C extends Context<F>,\n> extends Adapter<Y, MangoQuery, F, C> {\n  protected constructor(scope: Y, flavour: string, alias?: string) {\n    super(scope, flavour, alias);\n    [this.create, this.createAll, this.update, this.updateAll].forEach((m) => {\n      const name = m.name;\n      prefixMethod(this, m, (this as any)[name + \"Prefix\"]);\n    });\n  }\n\n  /**\n   * @description Creates a new CouchDB statement for querying\n   * @summary Factory method that creates a new CouchDBStatement instance for building queries\n   * @template M - The model type\n   * @return {CouchDBStatement<M, any>} A new CouchDBStatement instance\n   */\n  @final()\n  Statement<M extends Model>(): CouchDBStatement<M, any> {\n    return new CouchDBStatement(this);\n  }\n\n  /**\n   * @description Creates a new CouchDB sequence\n   * @summary Factory method that creates a new CouchDBSequence instance for managing sequences\n   * @param {SequenceOptions} options - The options for the sequence\n   * @return {Promise<Sequence>} A promise that resolves to a new Sequence instance\n   */\n  @final()\n  async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new CouchDBSequence(options, this);\n  }\n\n  /**\n   * @description Initializes the adapter by creating indexes for all managed models\n   * @summary Sets up the necessary database indexes for all models managed by this adapter\n   * @return {Promise<void>} A promise that resolves when initialization is complete\n   */\n  async initialize(): Promise<void> {\n    const managedModels = Adapter.models(this.flavour);\n    return this.index(...managedModels);\n  }\n\n  /**\n   * @description Creates indexes for the given models\n   * @summary Abstract method that must be implemented to create database indexes for the specified models\n   * @template M - The model type\n   * @param {...Constructor<M>} models - The model constructors to create indexes for\n   * @return {Promise<void>} A promise that resolves when all indexes are created\n   */\n  protected abstract index<M extends Model>(\n    ...models: Constructor<M>[]\n  ): Promise<void>;\n\n  /**\n   * @description Executes a raw Mango query against the database\n   * @summary Abstract method that must be implemented to execute raw Mango queries\n   * @template R - The result type\n   * @param {MangoQuery} rawInput - The raw Mango query to execute\n   * @param {boolean} docsOnly - Whether to return only the documents or the full response\n   * @return {Promise<R>} A promise that resolves to the query result\n   */\n  abstract override raw<R>(rawInput: MangoQuery, docsOnly: boolean): Promise<R>;\n\n  /**\n   * @description Assigns metadata to a model\n   * @summary Adds revision metadata to a model as a non-enumerable property\n   * @param {Record<string, any>} model - The model to assign metadata to\n   * @param {string} rev - The revision string to assign\n   * @return {Record<string, any>} The model with metadata assigned\n   */\n  @final()\n  protected assignMetadata(\n    model: Record<string, any>,\n    rev: string\n  ): Record<string, any> {\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: rev,\n    });\n    return model;\n  }\n\n  /**\n   * @description Assigns metadata to multiple models\n   * @summary Adds revision metadata to multiple models as non-enumerable properties\n   * @param models - The models to assign metadata to\n   * @param {string[]} revs - The revision strings to assign\n   * @return The models with metadata assigned\n   */\n  @final()\n  protected assignMultipleMetadata(\n    models: Record<string, any>[],\n    revs: string[]\n  ): Record<string, any>[] {\n    models.forEach((m, i) => {\n      Repository.setMetadata(m as any, revs[i]);\n      return m;\n    });\n    return models;\n  }\n\n  /**\n   * @description Prepares a record for creation\n   * @summary Adds necessary CouchDB fields to a record before creation\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {Record<string, any>} model - The model to prepare\n   * @return A tuple containing the tableName, id, and prepared record\n   */\n  @final()\n  protected createPrefix(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ) {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    return [tableName, id, record];\n  }\n\n  /**\n   * @description Creates a new record in the database\n   * @summary Abstract method that must be implemented to create a new record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {Record<string, any>} model - The model to create\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<Record<string, any>>} A promise that resolves to the created record\n   */\n  abstract override create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Prepares multiple records for creation\n   * @summary Adds necessary CouchDB fields to multiple records before creation\n   * @param {string} tableName - The name of the table\n   * @param {string[]|number[]} ids - The IDs of the records\n   * @param models - The models to prepare\n   * @return A tuple containing the tableName, ids, and prepared records\n   * @throws {InternalError} If ids and models arrays have different lengths\n   */\n  @final()\n  protected createAllPrefix(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ) {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      Object.assign(record, models[count]);\n      return record;\n    });\n    return [tableName, ids, records];\n  }\n\n  /**\n   * @description Reads a record from the database\n   * @summary Abstract method that must be implemented to read a record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {...any[]} args - Additional arguments\n   * @return {Promise<Record<string, any>>} A promise that resolves to the read record\n   */\n  abstract override read(\n    tableName: string,\n    id: string | number,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Prepares a record for update\n   * @summary Adds necessary CouchDB fields to a record before update\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param model - The model to prepare\n   * @return A tuple containing the tableName, id, and prepared record\n   * @throws {InternalError} If no revision number is found in the model\n   */\n  @final()\n  updatePrefix(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ) {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    const rev = model[PersistenceKeys.METADATA];\n    if (!rev)\n      throw new InternalError(\n        `No revision number found for record with id ${id}`\n      );\n    Object.assign(record, model);\n    record[CouchDBKeys.REV] = rev;\n    return [tableName, id, record];\n  }\n\n  /**\n   * @description Updates a record in the database\n   * @summary Abstract method that must be implemented to update a record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {Record<string, any>} model - The model to update\n   * @param {any[]} args - Additional arguments\n   * @return A promise that resolves to the updated record\n   */\n  abstract override update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Prepares multiple records for update\n   * @summary Adds necessary CouchDB fields to multiple records before update\n   * @param {string} tableName - The name of the table\n   * @param {string[]|number[]} ids - The IDs of the records\n   * @param models - The models to prepare\n   * @return A tuple containing the tableName, ids, and prepared records\n   * @throws {InternalError} If ids and models arrays have different lengths or if no revision number is found in a model\n   */\n  @final()\n  protected updateAllPrefix(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ) {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      const rev = models[count][PersistenceKeys.METADATA];\n      if (!rev)\n        throw new InternalError(\n          `No revision number found for record with id ${id}`\n        );\n      Object.assign(record, models[count]);\n      record[CouchDBKeys.REV] = rev;\n      return record;\n    });\n    return [tableName, ids, records];\n  }\n\n  /**\n   * @description Deletes a record from the database\n   * @summary Abstract method that must be implemented to delete a record\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @param {any[]} args - Additional arguments\n   * @return A promise that resolves to the deleted record\n   */\n  abstract override delete(\n    tableName: string,\n    id: string | number,\n    ...args: any[]\n  ): Promise<Record<string, any>>;\n\n  /**\n   * @description Generates a CouchDB document ID\n   * @summary Combines the table name and ID to create a CouchDB document ID\n   * @param {string} tableName - The name of the table\n   * @param {string|number} id - The ID of the record\n   * @return {string} The generated CouchDB document ID\n   */\n  protected generateId(tableName: string, id: string | number) {\n    return [tableName, id].join(CouchDBKeys.SEPARATOR);\n  }\n\n  /**\n   * @description Parses an error and converts it to a BaseError\n   * @summary Converts various error types to appropriate BaseError subtypes\n   * @param {Error|string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error as a BaseError\n   */\n  parseError(err: Error | string, reason?: string): BaseError {\n    return CouchDBAdapter.parseError(err, reason);\n  }\n\n  /**\n   * @description Checks if an attribute is reserved\n   * @summary Determines if an attribute name is reserved in CouchDB\n   * @param {string} attr - The attribute name to check\n   * @return {boolean} True if the attribute is reserved, false otherwise\n   */\n  protected override isReserved(attr: string): boolean {\n    return !!attr.match(reservedAttributes);\n  }\n\n  /**\n   * @description Static method to parse an error and convert it to a BaseError\n   * @summary Converts various error types to appropriate BaseError subtypes based on error codes and messages\n   * @param {Error|string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error as a BaseError\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant parseError\n   *   participant ErrorTypes\n   *\n   *   Caller->>parseError: err, reason\n   *   Note over parseError: Check if err is already a BaseError\n   *   alt err is BaseError\n   *     parseError-->>Caller: return err\n   *   else err is string\n   *     Note over parseError: Extract code from string\n   *     alt code matches \"already exist|update conflict\"\n   *       parseError->>ErrorTypes: new ConflictError(code)\n   *       ErrorTypes-->>Caller: ConflictError\n   *     else code matches \"missing|deleted\"\n   *       parseError->>ErrorTypes: new NotFoundError(code)\n   *       ErrorTypes-->>Caller: NotFoundError\n   *     end\n   *   else err has code property\n   *     Note over parseError: Extract code and reason\n   *   else err has statusCode property\n   *     Note over parseError: Extract code and reason\n   *   else\n   *     Note over parseError: Use err.message as code\n   *   end\n   *\n   *   Note over parseError: Switch on code\n   *   alt code is 401, 412, or 409\n   *     parseError->>ErrorTypes: new ConflictError(reason)\n   *     ErrorTypes-->>Caller: ConflictError\n   *   else code is 404\n   *     parseError->>ErrorTypes: new NotFoundError(reason)\n   *     ErrorTypes-->>Caller: NotFoundError\n   *   else code is 400\n   *     alt code matches \"No index exists\"\n   *       parseError->>ErrorTypes: new IndexError(err)\n   *       ErrorTypes-->>Caller: IndexError\n   *     else\n   *       parseError->>ErrorTypes: new InternalError(err)\n   *       ErrorTypes-->>Caller: InternalError\n   *     end\n   *   else code matches \"ECONNREFUSED\"\n   *     parseError->>ErrorTypes: new ConnectionError(err)\n   *     ErrorTypes-->>Caller: ConnectionError\n   *   else\n   *     parseError->>ErrorTypes: new InternalError(err)\n   *     ErrorTypes-->>Caller: InternalError\n   *   end\n   */\n  protected static parseError(err: Error | string, reason?: string): BaseError {\n    if (err instanceof BaseError) return err as any;\n    let code: string = \"\";\n    if (typeof err === \"string\") {\n      code = err;\n      if (code.match(/already exist|update conflict/g))\n        return new ConflictError(code);\n      if (code.match(/missing|deleted/g)) return new NotFoundError(code);\n    } else if ((err as any).code) {\n      code = (err as any).code;\n      reason = reason || err.message;\n    } else if ((err as any).statusCode) {\n      code = (err as any).statusCode;\n      reason = reason || err.message;\n    } else {\n      code = err.message;\n    }\n\n    switch (code.toString()) {\n      case \"401\":\n      case \"412\":\n      case \"409\":\n        return new ConflictError(reason as string);\n      case \"404\":\n        return new NotFoundError(reason as string);\n      case \"400\":\n        if (code.toString().match(/No\\sindex\\sexists/g))\n          return new IndexError(err);\n        return new InternalError(err);\n      default:\n        if (code.toString().match(/ECONNREFUSED/g))\n          return new ConnectionError(err);\n        return new InternalError(err);\n    }\n  }\n}\n","import { OrderDirection, PersistenceKeys } from \"@decaf-ts/core\";\nimport { CouchDBKeys } from \"./constants\";\nimport { DefaultSeparator } from \"@decaf-ts/db-decorators\";\nimport { CouchDBOperator } from \"./query/constants\";\nimport { CreateIndexRequest, MangoSelector, SortOrder } from \"./types\";\n\n/**\n * @description Re-authenticates a connection to CouchDB\n * @summary Refreshes the authentication for a CouchDB connection using the provided credentials\n * @param {any} con - The CouchDB connection object\n * @param {string} user - The username for authentication\n * @param {string} pass - The password for authentication\n * @return {Promise<any>} A promise that resolves to the authentication result\n * @function reAuth\n * @memberOf module:for-couchdb\n */\nexport async function reAuth(con: any, user: string, pass: string) {\n  return con.auth(user, pass);\n}\n\n/**\n * @description Wraps a CouchDB database connection with automatic re-authentication\n * @summary Creates a proxy around a CouchDB database connection that automatically re-authenticates before each operation\n * @param {any} con - The CouchDB connection object\n * @param {string} dbName - The name of the database to use\n * @param {string} user - The username for authentication\n * @param {string} pass - The password for authentication\n * @return {any} The wrapped database connection object\n * @function wrapDocumentScope\n * @memberOf module:for-couchdb\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant wrapDocumentScope\n *   participant DB\n *   participant reAuth\n *   \n *   Client->>wrapDocumentScope: con, dbName, user, pass\n *   wrapDocumentScope->>DB: con.use(dbName)\n *   Note over wrapDocumentScope: Wrap DB methods with re-auth\n *   \n *   loop For each method (insert, get, put, destroy, find)\n *     wrapDocumentScope->>wrapDocumentScope: Store original method\n *     wrapDocumentScope->>wrapDocumentScope: Define new method with re-auth\n *   end\n *   \n *   wrapDocumentScope->>wrapDocumentScope: Add NATIVE property with con value\n *   wrapDocumentScope-->>Client: Return wrapped DB\n *   \n *   Note over Client: Later when client uses DB methods\n *   Client->>DB: Any wrapped method call\n *   DB->>reAuth: Authenticate before operation\n *   reAuth-->>DB: Authentication complete\n *   DB->>DB: Call original method\n *   DB-->>Client: Return result\n */\nexport function wrapDocumentScope(\n  con: any,\n  dbName: string,\n  user: string,\n  pass: string\n): any {\n  const db = con.use(dbName);\n  [\"insert\", \"get\", \"put\", \"destroy\", \"find\"].forEach((k) => {\n    const original = (db as Record<string, any>)[k];\n    Object.defineProperty(db, k, {\n      enumerable: false,\n      configurable: true,\n      value: async (...args: any[]) => {\n        await reAuth(con, user, pass);\n        return original.call(db, ...args);\n      },\n    });\n  });\n  Object.defineProperty(db, CouchDBKeys.NATIVE, {\n    enumerable: false,\n    configurable: false,\n    writable: false,\n    value: con,\n  });\n  return db;\n}\n\n/**\n * @description Tests if an attribute name is reserved in CouchDB\n * @summary Checks if an attribute name starts with an underscore, which indicates it's a reserved attribute in CouchDB\n * @param {string} attr - The attribute name to test\n * @return {RegExpMatchArray|null} The match result or null if no match\n * @function testReservedAttributes\n * @memberOf module:for-couchdb\n */\nexport function testReservedAttributes(attr: string) {\n  const regexp = /^_.*$/g;\n  return attr.match(regexp);\n}\n\n/**\n * @description Generates a name for a CouchDB index\n * @summary Creates a standardized name for a CouchDB index based on the table, attribute, compositions, and order\n * @param {string} attribute - The primary attribute for the index\n * @param {string} tableName - The name of the table\n * @param {string[]} [compositions] - Optional additional attributes to include in the index\n * @param {OrderDirection} [order] - Optional sort order for the index\n * @param {string} [separator=DefaultSeparator] - The separator to use between parts of the index name\n * @return {string} The generated index name\n * @function generateIndexName\n * @memberOf module:for-couchdb\n */\nexport function generateIndexName(\n  attribute: string,\n  tableName: string,\n  compositions?: string[],\n  order?: OrderDirection,\n  separator = DefaultSeparator\n): string {\n  const attr = [PersistenceKeys.INDEX, tableName, attribute];\n  if (compositions) attr.push(...compositions);\n  if (order) attr.push(order);\n  return attr.join(separator);\n}\n\n/**\n * @description Generates a CouchDB index configuration\n * @summary Creates a complete CreateIndexRequest object for defining a CouchDB index based on specified parameters\n * @param {string} attribute - The primary attribute for the index\n * @param {string} tableName - The name of the table\n * @param {string[]} [compositions] - Optional additional attributes to include in the index\n * @param {OrderDirection} [order] - Optional sort order for the index\n * @param {string} [separator=DefaultSeparator] - The separator to use between parts of the index name\n * @return {CreateIndexRequest} The complete index configuration object\n * @function generateIndexDoc\n * @memberOf module:for-couchdb\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant generateIndexDoc\n *   participant generateIndexName\n *   \n *   Caller->>generateIndexDoc: attribute, tableName, compositions, order, separator\n *   \n *   Note over generateIndexDoc: Create partial filter selector\n *   generateIndexDoc->>generateIndexDoc: Set up filter for tableName\n *   \n *   alt order is specified\n *     Note over generateIndexDoc: Create ordered fields array\n *     generateIndexDoc->>generateIndexDoc: Create orderProp for attribute\n *     generateIndexDoc->>generateIndexDoc: Map compositions to ordered props\n *     generateIndexDoc->>generateIndexDoc: Create sortedTable for table field\n *     generateIndexDoc->>generateIndexDoc: Combine all ordered fields\n *   else\n *     Note over generateIndexDoc: Create simple fields array\n *     generateIndexDoc->>generateIndexDoc: Use attribute, compositions, and table as strings\n *   end\n *   \n *   generateIndexDoc->>generateIndexName: Generate index name\n *   generateIndexName-->>generateIndexDoc: Return name\n *   \n *   Note over generateIndexDoc: Create final index request\n *   generateIndexDoc-->>Caller: Return CreateIndexRequest\n */\nexport function generateIndexDoc(\n  attribute: string,\n  tableName: string,\n  compositions?: string[],\n  order?: OrderDirection,\n  separator = DefaultSeparator\n): CreateIndexRequest {\n  const partialFilterSelector: MangoSelector = {};\n  partialFilterSelector[CouchDBKeys.TABLE] = {} as MangoSelector;\n  (partialFilterSelector[CouchDBKeys.TABLE] as MangoSelector)[\n    CouchDBOperator.EQUAL\n  ] = tableName;\n  let fields: SortOrder[];\n  if (order) {\n    const orderProp: SortOrder = {};\n    orderProp[attribute] = order as \"asc\" | \"desc\";\n    const sortedCompositions: SortOrder[] = (compositions || []).map((c) => {\n      const r: SortOrder = {};\n      r[c] = order as \"asc\" | \"desc\";\n      return r;\n    });\n    const sortedTable: SortOrder = {};\n    sortedTable[CouchDBKeys.TABLE] = order as \"asc\" | \"desc\";\n    fields = [orderProp, ...sortedCompositions, sortedTable];\n  } else {\n    fields = [attribute, ...(compositions || []), CouchDBKeys.TABLE];\n  }\n  const name = generateIndexName(\n    attribute,\n    tableName,\n    compositions,\n    order,\n    separator\n  );\n  return {\n    index: {\n      fields: fields,\n      // partial_filter_selector: partialFilterSelector,\n    },\n    ddoc: [name, CouchDBKeys.DDOC].join(separator),\n    name: name,\n  };\n}\n","export * from \"./indexes\";\nexport * from \"./interfaces\";\nexport * from \"./model\";\nexport * from \"./sequences\";\nexport * from \"./adapter\";\nexport * from \"./constants\";\nexport * from \"./errors\";\nexport * from \"./types\";\nexport * from \"./utils\";\n\n/**\n * @description CouchDB adapter for Decaf.ts\n * @summary A TypeScript adapter for CouchDB database operations, providing a seamless integration with the Decaf.ts framework. This module includes classes, interfaces, and utilities for working with CouchDB databases, including support for Mango queries, document operations, and sequence management.\n * @module for-couchdb\n */\n\n/**\n * @description Stores the current package version\n * @summary The version string of the for-couchdb package\n * @const VERSION\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["generateIndexName","Sequence","Seq"],"mappings":"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"}
|