@model-ts/dynamodb 4.0.0 → 4.2.0
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/CHANGELOG.md +12 -0
- package/dist/cjs/__test__/client-env-guard.test.d.ts +1 -0
- package/dist/cjs/__test__/client-env-guard.test.js +28 -0
- package/dist/cjs/__test__/client-env-guard.test.js.map +1 -0
- package/dist/cjs/__test__/conformance.test.d.ts +1 -0
- package/dist/cjs/__test__/conformance.test.js +1835 -0
- package/dist/cjs/__test__/conformance.test.js.map +1 -0
- package/dist/cjs/__test__/in-memory.spec.test.d.ts +1 -0
- package/dist/cjs/__test__/in-memory.spec.test.js +185 -0
- package/dist/cjs/__test__/in-memory.spec.test.js.map +1 -0
- package/dist/cjs/__test__/rollback.test.d.ts +1 -0
- package/dist/cjs/__test__/rollback.test.js +196 -0
- package/dist/cjs/__test__/rollback.test.js.map +1 -0
- package/dist/cjs/client.d.ts +2 -2
- package/dist/cjs/client.js +14 -6
- package/dist/cjs/client.js.map +1 -1
- package/dist/cjs/errors.d.ts +13 -1
- package/dist/cjs/errors.js +12 -1
- package/dist/cjs/errors.js.map +1 -1
- package/dist/cjs/in-memory/document-client.d.ts +45 -0
- package/dist/cjs/in-memory/document-client.js +795 -0
- package/dist/cjs/in-memory/document-client.js.map +1 -0
- package/dist/cjs/in-memory/expression.d.ts +42 -0
- package/dist/cjs/in-memory/expression.js +585 -0
- package/dist/cjs/in-memory/expression.js.map +1 -0
- package/dist/cjs/in-memory/index.d.ts +2 -0
- package/dist/cjs/in-memory/index.js +6 -0
- package/dist/cjs/in-memory/index.js.map +1 -0
- package/dist/cjs/in-memory/spec.d.ts +23 -0
- package/dist/cjs/in-memory/spec.js +141 -0
- package/dist/cjs/in-memory/spec.js.map +1 -0
- package/dist/cjs/in-memory/store.d.ts +73 -0
- package/dist/cjs/in-memory/store.js +267 -0
- package/dist/cjs/in-memory/store.js.map +1 -0
- package/dist/cjs/in-memory/treap.d.ts +31 -0
- package/dist/cjs/in-memory/treap.js +187 -0
- package/dist/cjs/in-memory/treap.js.map +1 -0
- package/dist/cjs/in-memory/utils.d.ts +10 -0
- package/dist/cjs/in-memory/utils.js +38 -0
- package/dist/cjs/in-memory/utils.js.map +1 -0
- package/dist/cjs/sandbox.d.ts +2 -0
- package/dist/cjs/sandbox.js +172 -1
- package/dist/cjs/sandbox.js.map +1 -1
- package/dist/esm/__test__/client-env-guard.test.d.ts +1 -0
- package/dist/esm/__test__/client-env-guard.test.js +26 -0
- package/dist/esm/__test__/client-env-guard.test.js.map +1 -0
- package/dist/esm/__test__/conformance.test.d.ts +1 -0
- package/dist/esm/__test__/conformance.test.js +1833 -0
- package/dist/esm/__test__/conformance.test.js.map +1 -0
- package/dist/esm/__test__/in-memory.spec.test.d.ts +1 -0
- package/dist/esm/__test__/in-memory.spec.test.js +183 -0
- package/dist/esm/__test__/in-memory.spec.test.js.map +1 -0
- package/dist/esm/__test__/rollback.test.d.ts +1 -0
- package/dist/esm/__test__/rollback.test.js +194 -0
- package/dist/esm/__test__/rollback.test.js.map +1 -0
- package/dist/esm/client.d.ts +2 -2
- package/dist/esm/client.js +14 -6
- package/dist/esm/client.js.map +1 -1
- package/dist/esm/errors.d.ts +13 -1
- package/dist/esm/errors.js +10 -0
- package/dist/esm/errors.js.map +1 -1
- package/dist/esm/in-memory/document-client.d.ts +45 -0
- package/dist/esm/in-memory/document-client.js +791 -0
- package/dist/esm/in-memory/document-client.js.map +1 -0
- package/dist/esm/in-memory/expression.d.ts +42 -0
- package/dist/esm/in-memory/expression.js +577 -0
- package/dist/esm/in-memory/expression.js.map +1 -0
- package/dist/esm/in-memory/index.d.ts +2 -0
- package/dist/esm/in-memory/index.js +3 -0
- package/dist/esm/in-memory/index.js.map +1 -0
- package/dist/esm/in-memory/spec.d.ts +23 -0
- package/dist/esm/in-memory/spec.js +138 -0
- package/dist/esm/in-memory/spec.js.map +1 -0
- package/dist/esm/in-memory/store.d.ts +73 -0
- package/dist/esm/in-memory/store.js +258 -0
- package/dist/esm/in-memory/store.js.map +1 -0
- package/dist/esm/in-memory/treap.d.ts +31 -0
- package/dist/esm/in-memory/treap.js +183 -0
- package/dist/esm/in-memory/treap.js.map +1 -0
- package/dist/esm/in-memory/utils.d.ts +10 -0
- package/dist/esm/in-memory/utils.js +28 -0
- package/dist/esm/in-memory/utils.js.map +1 -0
- package/dist/esm/sandbox.d.ts +2 -0
- package/dist/esm/sandbox.js +172 -1
- package/dist/esm/sandbox.js.map +1 -1
- package/package.json +2 -1
- package/src/__test__/client-env-guard.test.ts +31 -0
- package/src/__test__/conformance.test.ts +2042 -0
- package/src/__test__/in-memory.spec.test.ts +230 -0
- package/src/__test__/rollback.test.ts +279 -0
- package/src/client.ts +17 -4
- package/src/errors.ts +24 -0
- package/src/in-memory/document-client.ts +1140 -0
- package/src/in-memory/expression.ts +730 -0
- package/src/in-memory/index.ts +2 -0
- package/src/in-memory/spec.ts +159 -0
- package/src/in-memory/store.ts +360 -0
- package/src/in-memory/treap.ts +239 -0
- package/src/in-memory/utils.ts +45 -0
- package/src/sandbox.ts +227 -1
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IN_MEMORY_CONDITIONS = exports.IN_MEMORY_SPEC = exports.IN_MEMORY_INDEXES = void 0;
|
|
4
|
+
const gsi_1 = require("../gsi");
|
|
5
|
+
exports.IN_MEMORY_INDEXES = [
|
|
6
|
+
"primary",
|
|
7
|
+
...gsi_1.GSI_NAMES,
|
|
8
|
+
];
|
|
9
|
+
exports.IN_MEMORY_SPEC = {
|
|
10
|
+
version: "2026-02-09",
|
|
11
|
+
scope: "model-ts/dynamodb",
|
|
12
|
+
projection: "ALL",
|
|
13
|
+
excludedIndexes: ["GSI1"],
|
|
14
|
+
indexes: exports.IN_MEMORY_INDEXES,
|
|
15
|
+
methods: {
|
|
16
|
+
get: {
|
|
17
|
+
supportedParams: ["TableName", "Key", "ConsistentRead"],
|
|
18
|
+
unsupportedParams: [
|
|
19
|
+
"AttributesToGet",
|
|
20
|
+
"ProjectionExpression",
|
|
21
|
+
"ExpressionAttributeNames",
|
|
22
|
+
],
|
|
23
|
+
},
|
|
24
|
+
put: {
|
|
25
|
+
supportedParams: [
|
|
26
|
+
"TableName",
|
|
27
|
+
"Item",
|
|
28
|
+
"ConditionExpression",
|
|
29
|
+
"ExpressionAttributeNames",
|
|
30
|
+
"ExpressionAttributeValues",
|
|
31
|
+
],
|
|
32
|
+
unsupportedParams: [
|
|
33
|
+
"Expected",
|
|
34
|
+
"ReturnValues",
|
|
35
|
+
"ReturnConsumedCapacity",
|
|
36
|
+
"ReturnItemCollectionMetrics",
|
|
37
|
+
],
|
|
38
|
+
},
|
|
39
|
+
update: {
|
|
40
|
+
supportedParams: [
|
|
41
|
+
"TableName",
|
|
42
|
+
"Key",
|
|
43
|
+
"ConditionExpression",
|
|
44
|
+
"UpdateExpression",
|
|
45
|
+
"ExpressionAttributeNames",
|
|
46
|
+
"ExpressionAttributeValues",
|
|
47
|
+
"ReturnValues",
|
|
48
|
+
],
|
|
49
|
+
unsupportedParams: [
|
|
50
|
+
"Expected",
|
|
51
|
+
"AttributeUpdates",
|
|
52
|
+
"ReturnConsumedCapacity",
|
|
53
|
+
"ReturnItemCollectionMetrics",
|
|
54
|
+
],
|
|
55
|
+
},
|
|
56
|
+
delete: {
|
|
57
|
+
supportedParams: [
|
|
58
|
+
"TableName",
|
|
59
|
+
"Key",
|
|
60
|
+
"ConditionExpression",
|
|
61
|
+
"ExpressionAttributeNames",
|
|
62
|
+
"ExpressionAttributeValues",
|
|
63
|
+
],
|
|
64
|
+
unsupportedParams: [
|
|
65
|
+
"Expected",
|
|
66
|
+
"ReturnValues",
|
|
67
|
+
"ReturnConsumedCapacity",
|
|
68
|
+
"ReturnItemCollectionMetrics",
|
|
69
|
+
],
|
|
70
|
+
},
|
|
71
|
+
query: {
|
|
72
|
+
supportedParams: [
|
|
73
|
+
"TableName",
|
|
74
|
+
"IndexName",
|
|
75
|
+
"KeyConditionExpression",
|
|
76
|
+
"FilterExpression",
|
|
77
|
+
"ExpressionAttributeNames",
|
|
78
|
+
"ExpressionAttributeValues",
|
|
79
|
+
"Limit",
|
|
80
|
+
"ExclusiveStartKey",
|
|
81
|
+
"ScanIndexForward",
|
|
82
|
+
"ConsistentRead",
|
|
83
|
+
],
|
|
84
|
+
unsupportedParams: [
|
|
85
|
+
"Select",
|
|
86
|
+
"ProjectionExpression",
|
|
87
|
+
"KeyConditions",
|
|
88
|
+
"QueryFilter",
|
|
89
|
+
"ConditionalOperator",
|
|
90
|
+
"AttributesToGet",
|
|
91
|
+
],
|
|
92
|
+
},
|
|
93
|
+
scan: {
|
|
94
|
+
supportedParams: [
|
|
95
|
+
"TableName",
|
|
96
|
+
"FilterExpression",
|
|
97
|
+
"ExpressionAttributeNames",
|
|
98
|
+
"ExpressionAttributeValues",
|
|
99
|
+
"Limit",
|
|
100
|
+
"ExclusiveStartKey",
|
|
101
|
+
],
|
|
102
|
+
unsupportedParams: [
|
|
103
|
+
"ProjectionExpression",
|
|
104
|
+
"Segment",
|
|
105
|
+
"TotalSegments",
|
|
106
|
+
"Select",
|
|
107
|
+
"ScanFilter",
|
|
108
|
+
],
|
|
109
|
+
},
|
|
110
|
+
batchGet: {
|
|
111
|
+
supportedParams: ["RequestItems"],
|
|
112
|
+
unsupportedParams: ["ReturnConsumedCapacity"],
|
|
113
|
+
},
|
|
114
|
+
batchWrite: {
|
|
115
|
+
supportedParams: ["RequestItems"],
|
|
116
|
+
unsupportedParams: ["ReturnConsumedCapacity", "ReturnItemCollectionMetrics"],
|
|
117
|
+
},
|
|
118
|
+
transactWrite: {
|
|
119
|
+
supportedParams: ["TransactItems"],
|
|
120
|
+
unsupportedParams: [
|
|
121
|
+
"ClientRequestToken",
|
|
122
|
+
"ReturnConsumedCapacity",
|
|
123
|
+
"ReturnItemCollectionMetrics",
|
|
124
|
+
],
|
|
125
|
+
},
|
|
126
|
+
},
|
|
127
|
+
unsupportedMethods: [
|
|
128
|
+
"createSet",
|
|
129
|
+
"transactGet",
|
|
130
|
+
"putItem",
|
|
131
|
+
"deleteItem",
|
|
132
|
+
"updateItem",
|
|
133
|
+
"queryItems",
|
|
134
|
+
"scanItems",
|
|
135
|
+
],
|
|
136
|
+
};
|
|
137
|
+
exports.IN_MEMORY_CONDITIONS = {
|
|
138
|
+
excludedGSI: "GSI1 is intentionally excluded from in-memory mode.",
|
|
139
|
+
gsiProjection: "All GSIs are treated as full projection for in-scope behavior.",
|
|
140
|
+
};
|
|
141
|
+
//# sourceMappingURL=spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spec.js","sourceRoot":"","sources":["../../../src/in-memory/spec.ts"],"names":[],"mappings":";;;AAAA,gCAAuC;AAqB1B,QAAA,iBAAiB,GAAwB;IACpD,SAAS;IACT,GAAG,eAAS;CACb,CAAA;AAEY,QAAA,cAAc,GAAiB;IAC1C,OAAO,EAAE,YAAY;IACrB,KAAK,EAAE,mBAAmB;IAC1B,UAAU,EAAE,KAAK;IACjB,eAAe,EAAE,CAAC,MAAM,CAAC;IACzB,OAAO,EAAE,yBAAiB;IAC1B,OAAO,EAAE;QACP,GAAG,EAAE;YACH,eAAe,EAAE,CAAC,WAAW,EAAE,KAAK,EAAE,gBAAgB,CAAC;YACvD,iBAAiB,EAAE;gBACjB,iBAAiB;gBACjB,sBAAsB;gBACtB,0BAA0B;aAC3B;SACF;QACD,GAAG,EAAE;YACH,eAAe,EAAE;gBACf,WAAW;gBACX,MAAM;gBACN,qBAAqB;gBACrB,0BAA0B;gBAC1B,2BAA2B;aAC5B;YACD,iBAAiB,EAAE;gBACjB,UAAU;gBACV,cAAc;gBACd,wBAAwB;gBACxB,6BAA6B;aAC9B;SACF;QACD,MAAM,EAAE;YACN,eAAe,EAAE;gBACf,WAAW;gBACX,KAAK;gBACL,qBAAqB;gBACrB,kBAAkB;gBAClB,0BAA0B;gBAC1B,2BAA2B;gBAC3B,cAAc;aACf;YACD,iBAAiB,EAAE;gBACjB,UAAU;gBACV,kBAAkB;gBAClB,wBAAwB;gBACxB,6BAA6B;aAC9B;SACF;QACD,MAAM,EAAE;YACN,eAAe,EAAE;gBACf,WAAW;gBACX,KAAK;gBACL,qBAAqB;gBACrB,0BAA0B;gBAC1B,2BAA2B;aAC5B;YACD,iBAAiB,EAAE;gBACjB,UAAU;gBACV,cAAc;gBACd,wBAAwB;gBACxB,6BAA6B;aAC9B;SACF;QACD,KAAK,EAAE;YACL,eAAe,EAAE;gBACf,WAAW;gBACX,WAAW;gBACX,wBAAwB;gBACxB,kBAAkB;gBAClB,0BAA0B;gBAC1B,2BAA2B;gBAC3B,OAAO;gBACP,mBAAmB;gBACnB,kBAAkB;gBAClB,gBAAgB;aACjB;YACD,iBAAiB,EAAE;gBACjB,QAAQ;gBACR,sBAAsB;gBACtB,eAAe;gBACf,aAAa;gBACb,qBAAqB;gBACrB,iBAAiB;aAClB;SACF;QACD,IAAI,EAAE;YACJ,eAAe,EAAE;gBACf,WAAW;gBACX,kBAAkB;gBAClB,0BAA0B;gBAC1B,2BAA2B;gBAC3B,OAAO;gBACP,mBAAmB;aACpB;YACD,iBAAiB,EAAE;gBACjB,sBAAsB;gBACtB,SAAS;gBACT,eAAe;gBACf,QAAQ;gBACR,YAAY;aACb;SACF;QACD,QAAQ,EAAE;YACR,eAAe,EAAE,CAAC,cAAc,CAAC;YACjC,iBAAiB,EAAE,CAAC,wBAAwB,CAAC;SAC9C;QACD,UAAU,EAAE;YACV,eAAe,EAAE,CAAC,cAAc,CAAC;YACjC,iBAAiB,EAAE,CAAC,wBAAwB,EAAE,6BAA6B,CAAC;SAC7E;QACD,aAAa,EAAE;YACb,eAAe,EAAE,CAAC,eAAe,CAAC;YAClC,iBAAiB,EAAE;gBACjB,oBAAoB;gBACpB,wBAAwB;gBACxB,6BAA6B;aAC9B;SACF;KACF;IACD,kBAAkB,EAAE;QAClB,WAAW;QACX,aAAa;QACb,SAAS;QACT,YAAY;QACZ,YAAY;QACZ,YAAY;QACZ,WAAW;KACZ;CACF,CAAA;AAEY,QAAA,oBAAoB,GAAG;IAClC,WAAW,EAAE,qDAAqD;IAClE,aAAa,EAAE,gEAAgE;CAChF,CAAA"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { ParsedKeyCondition, RangeCondition } from "./expression";
|
|
2
|
+
import { InMemoryItem } from "./utils";
|
|
3
|
+
import { InMemoryIndexName } from "./spec";
|
|
4
|
+
interface IndexDescriptor {
|
|
5
|
+
name: InMemoryIndexName;
|
|
6
|
+
hashAttribute: string;
|
|
7
|
+
rangeAttribute: string;
|
|
8
|
+
}
|
|
9
|
+
export declare const PRIMARY_INDEX_NAME: InMemoryIndexName;
|
|
10
|
+
export interface QueryCandidate {
|
|
11
|
+
entryKey: string;
|
|
12
|
+
itemKey: string;
|
|
13
|
+
item: InMemoryItem;
|
|
14
|
+
}
|
|
15
|
+
export interface QueryCursor {
|
|
16
|
+
itemKey: string;
|
|
17
|
+
rangeKey: string;
|
|
18
|
+
}
|
|
19
|
+
export declare class InMemoryTableState {
|
|
20
|
+
private readonly itemStore;
|
|
21
|
+
private readonly indexes;
|
|
22
|
+
cloneItemByKey(key: {
|
|
23
|
+
PK: string;
|
|
24
|
+
SK: string;
|
|
25
|
+
}): InMemoryItem | undefined;
|
|
26
|
+
cloneItemByItemKey(itemKey: string): InMemoryItem | undefined;
|
|
27
|
+
put(item: InMemoryItem): InMemoryItem | undefined;
|
|
28
|
+
deleteByKey(key: {
|
|
29
|
+
PK: string;
|
|
30
|
+
SK: string;
|
|
31
|
+
}): InMemoryItem | undefined;
|
|
32
|
+
iterateQueryCandidates(args: {
|
|
33
|
+
indexName: InMemoryIndexName;
|
|
34
|
+
hashKey: string;
|
|
35
|
+
rangeCondition?: RangeCondition;
|
|
36
|
+
scanIndexForward: boolean;
|
|
37
|
+
exclusiveStartKey?: QueryCursor;
|
|
38
|
+
}): IterableIterator<QueryCandidate>;
|
|
39
|
+
scanItems(exclusiveStartKey?: {
|
|
40
|
+
PK: string;
|
|
41
|
+
SK: string;
|
|
42
|
+
}): InMemoryItem[];
|
|
43
|
+
createQueryCursor(indexName: InMemoryIndexName, item: InMemoryItem): QueryCursor;
|
|
44
|
+
getIndexKeyFromItem(indexName: InMemoryIndexName, item: InMemoryItem): {
|
|
45
|
+
hash: string;
|
|
46
|
+
range: string;
|
|
47
|
+
} | null;
|
|
48
|
+
getDescriptor(indexName: InMemoryIndexName): IndexDescriptor;
|
|
49
|
+
hasItem(key: {
|
|
50
|
+
PK: string;
|
|
51
|
+
SK: string;
|
|
52
|
+
}): boolean;
|
|
53
|
+
snapshot(): {
|
|
54
|
+
[key: string]: any;
|
|
55
|
+
};
|
|
56
|
+
clear(): void;
|
|
57
|
+
private getValidatedPrimaryKey;
|
|
58
|
+
private addToIndexes;
|
|
59
|
+
private removeFromIndexes;
|
|
60
|
+
private toTreapBounds;
|
|
61
|
+
}
|
|
62
|
+
export declare const isGSI: (indexName: InMemoryIndexName) => indexName is "GSI2" | "GSI3" | "GSI4" | "GSI5" | "GSI6" | "GSI7" | "GSI8" | "GSI9" | "GSI10" | "GSI11" | "GSI12" | "GSI13" | "GSI14" | "GSI15" | "GSI16" | "GSI17" | "GSI18" | "GSI19";
|
|
63
|
+
export declare const parseIndexName: (indexName?: string | undefined) => InMemoryIndexName;
|
|
64
|
+
export declare const isSupportedIndexName: (indexName: string) => indexName is InMemoryIndexName;
|
|
65
|
+
export declare const matchesKeyConditionDescriptor: (indexName: InMemoryIndexName, condition: ParsedKeyCondition) => boolean;
|
|
66
|
+
export declare const compareItemKey: (left: {
|
|
67
|
+
PK: string;
|
|
68
|
+
SK: string;
|
|
69
|
+
}, right: {
|
|
70
|
+
PK: string;
|
|
71
|
+
SK: string;
|
|
72
|
+
}) => number;
|
|
73
|
+
export {};
|
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.compareItemKey = exports.matchesKeyConditionDescriptor = exports.isSupportedIndexName = exports.parseIndexName = exports.isGSI = exports.InMemoryTableState = exports.PRIMARY_INDEX_NAME = void 0;
|
|
4
|
+
const gsi_1 = require("../gsi");
|
|
5
|
+
const expression_1 = require("./expression");
|
|
6
|
+
const treap_1 = require("./treap");
|
|
7
|
+
const utils_1 = require("./utils");
|
|
8
|
+
exports.PRIMARY_INDEX_NAME = "primary";
|
|
9
|
+
const INDEX_DESCRIPTORS = [
|
|
10
|
+
{
|
|
11
|
+
name: exports.PRIMARY_INDEX_NAME,
|
|
12
|
+
hashAttribute: "PK",
|
|
13
|
+
rangeAttribute: "SK",
|
|
14
|
+
},
|
|
15
|
+
...gsi_1.GSI_NAMES.map((name) => ({
|
|
16
|
+
name,
|
|
17
|
+
hashAttribute: `${name}PK`,
|
|
18
|
+
rangeAttribute: `${name}SK`,
|
|
19
|
+
})),
|
|
20
|
+
];
|
|
21
|
+
const INDEX_BY_NAME = Object.fromEntries(INDEX_DESCRIPTORS.map((descriptor) => [descriptor.name, descriptor]));
|
|
22
|
+
class InMemoryTableState {
|
|
23
|
+
constructor() {
|
|
24
|
+
this.itemStore = new Map();
|
|
25
|
+
this.indexes = new Map(INDEX_DESCRIPTORS.map((descriptor) => [descriptor.name, new Map()]));
|
|
26
|
+
}
|
|
27
|
+
cloneItemByKey(key) {
|
|
28
|
+
return this.cloneItemByItemKey(utils_1.encodeItemKey(key.PK, key.SK));
|
|
29
|
+
}
|
|
30
|
+
cloneItemByItemKey(itemKey) {
|
|
31
|
+
const existing = this.itemStore.get(itemKey);
|
|
32
|
+
return existing ? utils_1.cloneItem(existing) : undefined;
|
|
33
|
+
}
|
|
34
|
+
put(item) {
|
|
35
|
+
const key = this.getValidatedPrimaryKey(item);
|
|
36
|
+
const itemKey = utils_1.encodeItemKey(key.PK, key.SK);
|
|
37
|
+
const previous = this.itemStore.get(itemKey);
|
|
38
|
+
if (previous) {
|
|
39
|
+
this.removeFromIndexes(itemKey, previous);
|
|
40
|
+
}
|
|
41
|
+
const stored = utils_1.cloneItem(item);
|
|
42
|
+
this.itemStore.set(itemKey, stored);
|
|
43
|
+
this.addToIndexes(itemKey, stored);
|
|
44
|
+
return previous ? utils_1.cloneItem(previous) : undefined;
|
|
45
|
+
}
|
|
46
|
+
deleteByKey(key) {
|
|
47
|
+
const itemKey = utils_1.encodeItemKey(key.PK, key.SK);
|
|
48
|
+
const previous = this.itemStore.get(itemKey);
|
|
49
|
+
if (!previous)
|
|
50
|
+
return undefined;
|
|
51
|
+
this.itemStore.delete(itemKey);
|
|
52
|
+
this.removeFromIndexes(itemKey, previous);
|
|
53
|
+
return utils_1.cloneItem(previous);
|
|
54
|
+
}
|
|
55
|
+
iterateQueryCandidates(args) {
|
|
56
|
+
var _a;
|
|
57
|
+
const descriptor = INDEX_BY_NAME[args.indexName];
|
|
58
|
+
const partition = (_a = this.indexes.get(args.indexName)) === null || _a === void 0 ? void 0 : _a.get(args.hashKey);
|
|
59
|
+
if (!partition) {
|
|
60
|
+
return [][Symbol.iterator]();
|
|
61
|
+
}
|
|
62
|
+
const bounds = this.toTreapBounds(args.rangeCondition);
|
|
63
|
+
const direction = args.scanIndexForward ? "asc" : "desc";
|
|
64
|
+
const iterator = partition.iterate(direction, bounds);
|
|
65
|
+
const exclusiveStartEntryKey = args.exclusiveStartKey
|
|
66
|
+
? utils_1.encodeIndexEntryKey(args.exclusiveStartKey.rangeKey, args.exclusiveStartKey.itemKey)
|
|
67
|
+
: undefined;
|
|
68
|
+
const table = this;
|
|
69
|
+
function* generate() {
|
|
70
|
+
for (const { key: entryKey, value: itemKey } of iterator) {
|
|
71
|
+
if (exclusiveStartEntryKey) {
|
|
72
|
+
if (direction === "asc" && entryKey <= exclusiveStartEntryKey) {
|
|
73
|
+
continue;
|
|
74
|
+
}
|
|
75
|
+
if (direction === "desc" && entryKey >= exclusiveStartEntryKey) {
|
|
76
|
+
continue;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
const item = table.itemStore.get(itemKey);
|
|
80
|
+
if (!item)
|
|
81
|
+
continue;
|
|
82
|
+
if (args.rangeCondition) {
|
|
83
|
+
const rangeValue = item[descriptor.rangeAttribute];
|
|
84
|
+
if (!expression_1.matchesRangeCondition(rangeValue, args.rangeCondition))
|
|
85
|
+
continue;
|
|
86
|
+
}
|
|
87
|
+
yield {
|
|
88
|
+
entryKey,
|
|
89
|
+
itemKey,
|
|
90
|
+
item: utils_1.cloneItem(item),
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return generate();
|
|
95
|
+
}
|
|
96
|
+
scanItems(exclusiveStartKey) {
|
|
97
|
+
const sorted = utils_1.sortItemsByPKSK([...this.itemStore.values()].map(utils_1.cloneItem));
|
|
98
|
+
if (!exclusiveStartKey)
|
|
99
|
+
return sorted;
|
|
100
|
+
const startPK = exclusiveStartKey.PK;
|
|
101
|
+
const startSK = exclusiveStartKey.SK;
|
|
102
|
+
return sorted.filter((item) => {
|
|
103
|
+
const pk = String(item.PK);
|
|
104
|
+
const sk = String(item.SK);
|
|
105
|
+
if (pk > startPK)
|
|
106
|
+
return true;
|
|
107
|
+
if (pk < startPK)
|
|
108
|
+
return false;
|
|
109
|
+
return sk > startSK;
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
createQueryCursor(indexName, item) {
|
|
113
|
+
const descriptor = INDEX_BY_NAME[indexName];
|
|
114
|
+
return {
|
|
115
|
+
itemKey: utils_1.encodeItemKey(String(item.PK), String(item.SK)),
|
|
116
|
+
rangeKey: String(item[descriptor.rangeAttribute]),
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
getIndexKeyFromItem(indexName, item) {
|
|
120
|
+
const descriptor = INDEX_BY_NAME[indexName];
|
|
121
|
+
const hash = item[descriptor.hashAttribute];
|
|
122
|
+
const range = item[descriptor.rangeAttribute];
|
|
123
|
+
if (indexName === exports.PRIMARY_INDEX_NAME) {
|
|
124
|
+
if (typeof hash !== "string" || typeof range !== "string")
|
|
125
|
+
return null;
|
|
126
|
+
return { hash, range };
|
|
127
|
+
}
|
|
128
|
+
if (typeof hash !== "string" || typeof range !== "string")
|
|
129
|
+
return null;
|
|
130
|
+
return { hash, range };
|
|
131
|
+
}
|
|
132
|
+
getDescriptor(indexName) {
|
|
133
|
+
return INDEX_BY_NAME[indexName];
|
|
134
|
+
}
|
|
135
|
+
hasItem(key) {
|
|
136
|
+
return this.itemStore.has(utils_1.encodeItemKey(key.PK, key.SK));
|
|
137
|
+
}
|
|
138
|
+
snapshot() {
|
|
139
|
+
const entries = utils_1.sortItemsByPKSK([...this.itemStore.values()]).map(utils_1.cloneItem);
|
|
140
|
+
return Object.fromEntries(entries.map((item) => [`${item.PK}__${item.SK}`, item]));
|
|
141
|
+
}
|
|
142
|
+
clear() {
|
|
143
|
+
this.itemStore.clear();
|
|
144
|
+
for (const partitionMap of this.indexes.values()) {
|
|
145
|
+
partitionMap.clear();
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
getValidatedPrimaryKey(item) {
|
|
149
|
+
if (typeof item.PK !== "string" || typeof item.SK !== "string") {
|
|
150
|
+
throw new Error("Primary key attributes PK and SK must be strings.");
|
|
151
|
+
}
|
|
152
|
+
return { PK: item.PK, SK: item.SK };
|
|
153
|
+
}
|
|
154
|
+
addToIndexes(itemKey, item) {
|
|
155
|
+
var _a;
|
|
156
|
+
for (const descriptor of INDEX_DESCRIPTORS) {
|
|
157
|
+
const projected = this.getIndexKeyFromItem(descriptor.name, item);
|
|
158
|
+
if (!projected)
|
|
159
|
+
continue;
|
|
160
|
+
const partitionMap = this.indexes.get(descriptor.name);
|
|
161
|
+
const tree = (_a = partitionMap.get(projected.hash)) !== null && _a !== void 0 ? _a : (() => {
|
|
162
|
+
const created = new treap_1.DeterministicTreap();
|
|
163
|
+
partitionMap.set(projected.hash, created);
|
|
164
|
+
return created;
|
|
165
|
+
})();
|
|
166
|
+
const entryKey = utils_1.encodeIndexEntryKey(projected.range, itemKey);
|
|
167
|
+
tree.insert(entryKey, itemKey, utils_1.stablePriority(descriptor.name, projected.hash, projected.range, itemKey));
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
removeFromIndexes(itemKey, item) {
|
|
171
|
+
for (const descriptor of INDEX_DESCRIPTORS) {
|
|
172
|
+
const projected = this.getIndexKeyFromItem(descriptor.name, item);
|
|
173
|
+
if (!projected)
|
|
174
|
+
continue;
|
|
175
|
+
const partitionMap = this.indexes.get(descriptor.name);
|
|
176
|
+
const tree = partitionMap.get(projected.hash);
|
|
177
|
+
if (!tree)
|
|
178
|
+
continue;
|
|
179
|
+
const entryKey = utils_1.encodeIndexEntryKey(projected.range, itemKey);
|
|
180
|
+
tree.remove(entryKey);
|
|
181
|
+
if (tree.size === 0) {
|
|
182
|
+
partitionMap.delete(projected.hash);
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
toTreapBounds(rangeCondition) {
|
|
187
|
+
if (!rangeCondition)
|
|
188
|
+
return {};
|
|
189
|
+
switch (rangeCondition.type) {
|
|
190
|
+
case "begins_with": {
|
|
191
|
+
const lower = utils_1.encodeIndexEntryKey(rangeCondition.value, "");
|
|
192
|
+
const upper = utils_1.encodeIndexEntryKey(`${rangeCondition.value}\uffff`, "");
|
|
193
|
+
return {
|
|
194
|
+
lower: { key: lower, inclusive: true },
|
|
195
|
+
upper: { key: upper, inclusive: true },
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
case "between": {
|
|
199
|
+
const lower = utils_1.encodeIndexEntryKey(String(rangeCondition.lower), "");
|
|
200
|
+
const upper = utils_1.encodeIndexEntryKey(String(rangeCondition.upper), "\uffff");
|
|
201
|
+
return {
|
|
202
|
+
lower: { key: lower, inclusive: true },
|
|
203
|
+
upper: { key: upper, inclusive: true },
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
case "=": {
|
|
207
|
+
const key = String(rangeCondition.value);
|
|
208
|
+
return {
|
|
209
|
+
lower: { key: utils_1.encodeIndexEntryKey(key, ""), inclusive: true },
|
|
210
|
+
upper: { key: utils_1.encodeIndexEntryKey(key, "\uffff"), inclusive: true },
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
case ">":
|
|
214
|
+
return {
|
|
215
|
+
lower: {
|
|
216
|
+
key: utils_1.encodeIndexEntryKey(String(rangeCondition.value), "\uffff"),
|
|
217
|
+
inclusive: false,
|
|
218
|
+
},
|
|
219
|
+
};
|
|
220
|
+
case ">=":
|
|
221
|
+
return {
|
|
222
|
+
lower: {
|
|
223
|
+
key: utils_1.encodeIndexEntryKey(String(rangeCondition.value), ""),
|
|
224
|
+
inclusive: true,
|
|
225
|
+
},
|
|
226
|
+
};
|
|
227
|
+
case "<":
|
|
228
|
+
return {
|
|
229
|
+
upper: {
|
|
230
|
+
key: utils_1.encodeIndexEntryKey(String(rangeCondition.value), ""),
|
|
231
|
+
inclusive: false,
|
|
232
|
+
},
|
|
233
|
+
};
|
|
234
|
+
case "<=":
|
|
235
|
+
return {
|
|
236
|
+
upper: {
|
|
237
|
+
key: utils_1.encodeIndexEntryKey(String(rangeCondition.value), "\uffff"),
|
|
238
|
+
inclusive: true,
|
|
239
|
+
},
|
|
240
|
+
};
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
exports.InMemoryTableState = InMemoryTableState;
|
|
245
|
+
const isGSI = (indexName) => indexName !== exports.PRIMARY_INDEX_NAME;
|
|
246
|
+
exports.isGSI = isGSI;
|
|
247
|
+
const parseIndexName = (indexName) => (indexName !== null && indexName !== void 0 ? indexName : exports.PRIMARY_INDEX_NAME);
|
|
248
|
+
exports.parseIndexName = parseIndexName;
|
|
249
|
+
const isSupportedIndexName = (indexName) => indexName === exports.PRIMARY_INDEX_NAME || gsi_1.GSI_NAMES.includes(indexName);
|
|
250
|
+
exports.isSupportedIndexName = isSupportedIndexName;
|
|
251
|
+
const matchesKeyConditionDescriptor = (indexName, condition) => {
|
|
252
|
+
const descriptor = INDEX_BY_NAME[indexName];
|
|
253
|
+
if (condition.hashAttribute !== descriptor.hashAttribute)
|
|
254
|
+
return false;
|
|
255
|
+
if (!condition.range)
|
|
256
|
+
return true;
|
|
257
|
+
return condition.range.attribute === descriptor.rangeAttribute;
|
|
258
|
+
};
|
|
259
|
+
exports.matchesKeyConditionDescriptor = matchesKeyConditionDescriptor;
|
|
260
|
+
const compareItemKey = (left, right) => {
|
|
261
|
+
const pkCmp = expression_1.compareValues(left.PK, right.PK);
|
|
262
|
+
if (pkCmp !== 0)
|
|
263
|
+
return pkCmp;
|
|
264
|
+
return expression_1.compareValues(left.SK, right.SK);
|
|
265
|
+
};
|
|
266
|
+
exports.compareItemKey = compareItemKey;
|
|
267
|
+
//# sourceMappingURL=store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/in-memory/store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export interface TreapBounds {
|
|
2
|
+
lower?: {
|
|
3
|
+
key: string;
|
|
4
|
+
inclusive: boolean;
|
|
5
|
+
};
|
|
6
|
+
upper?: {
|
|
7
|
+
key: string;
|
|
8
|
+
inclusive: boolean;
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
export declare class DeterministicTreap<V> {
|
|
12
|
+
private root;
|
|
13
|
+
private _size;
|
|
14
|
+
get size(): number;
|
|
15
|
+
insert(key: string, value: V, priority: number): void;
|
|
16
|
+
remove(key: string): boolean;
|
|
17
|
+
has(key: string): boolean;
|
|
18
|
+
iterate(direction: "asc" | "desc", bounds?: TreapBounds): IterableIterator<{
|
|
19
|
+
key: string;
|
|
20
|
+
value: V;
|
|
21
|
+
}>;
|
|
22
|
+
clear(): void;
|
|
23
|
+
private rotateRight;
|
|
24
|
+
private rotateLeft;
|
|
25
|
+
private insertNode;
|
|
26
|
+
private removeNode;
|
|
27
|
+
private iterateAsc;
|
|
28
|
+
private iterateDesc;
|
|
29
|
+
private isBelowLowerBound;
|
|
30
|
+
private isAboveUpperBound;
|
|
31
|
+
}
|