@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.
Files changed (100) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/cjs/__test__/client-env-guard.test.d.ts +1 -0
  3. package/dist/cjs/__test__/client-env-guard.test.js +28 -0
  4. package/dist/cjs/__test__/client-env-guard.test.js.map +1 -0
  5. package/dist/cjs/__test__/conformance.test.d.ts +1 -0
  6. package/dist/cjs/__test__/conformance.test.js +1835 -0
  7. package/dist/cjs/__test__/conformance.test.js.map +1 -0
  8. package/dist/cjs/__test__/in-memory.spec.test.d.ts +1 -0
  9. package/dist/cjs/__test__/in-memory.spec.test.js +185 -0
  10. package/dist/cjs/__test__/in-memory.spec.test.js.map +1 -0
  11. package/dist/cjs/__test__/rollback.test.d.ts +1 -0
  12. package/dist/cjs/__test__/rollback.test.js +196 -0
  13. package/dist/cjs/__test__/rollback.test.js.map +1 -0
  14. package/dist/cjs/client.d.ts +2 -2
  15. package/dist/cjs/client.js +14 -6
  16. package/dist/cjs/client.js.map +1 -1
  17. package/dist/cjs/errors.d.ts +13 -1
  18. package/dist/cjs/errors.js +12 -1
  19. package/dist/cjs/errors.js.map +1 -1
  20. package/dist/cjs/in-memory/document-client.d.ts +45 -0
  21. package/dist/cjs/in-memory/document-client.js +795 -0
  22. package/dist/cjs/in-memory/document-client.js.map +1 -0
  23. package/dist/cjs/in-memory/expression.d.ts +42 -0
  24. package/dist/cjs/in-memory/expression.js +585 -0
  25. package/dist/cjs/in-memory/expression.js.map +1 -0
  26. package/dist/cjs/in-memory/index.d.ts +2 -0
  27. package/dist/cjs/in-memory/index.js +6 -0
  28. package/dist/cjs/in-memory/index.js.map +1 -0
  29. package/dist/cjs/in-memory/spec.d.ts +23 -0
  30. package/dist/cjs/in-memory/spec.js +141 -0
  31. package/dist/cjs/in-memory/spec.js.map +1 -0
  32. package/dist/cjs/in-memory/store.d.ts +73 -0
  33. package/dist/cjs/in-memory/store.js +267 -0
  34. package/dist/cjs/in-memory/store.js.map +1 -0
  35. package/dist/cjs/in-memory/treap.d.ts +31 -0
  36. package/dist/cjs/in-memory/treap.js +187 -0
  37. package/dist/cjs/in-memory/treap.js.map +1 -0
  38. package/dist/cjs/in-memory/utils.d.ts +10 -0
  39. package/dist/cjs/in-memory/utils.js +38 -0
  40. package/dist/cjs/in-memory/utils.js.map +1 -0
  41. package/dist/cjs/sandbox.d.ts +2 -0
  42. package/dist/cjs/sandbox.js +172 -1
  43. package/dist/cjs/sandbox.js.map +1 -1
  44. package/dist/esm/__test__/client-env-guard.test.d.ts +1 -0
  45. package/dist/esm/__test__/client-env-guard.test.js +26 -0
  46. package/dist/esm/__test__/client-env-guard.test.js.map +1 -0
  47. package/dist/esm/__test__/conformance.test.d.ts +1 -0
  48. package/dist/esm/__test__/conformance.test.js +1833 -0
  49. package/dist/esm/__test__/conformance.test.js.map +1 -0
  50. package/dist/esm/__test__/in-memory.spec.test.d.ts +1 -0
  51. package/dist/esm/__test__/in-memory.spec.test.js +183 -0
  52. package/dist/esm/__test__/in-memory.spec.test.js.map +1 -0
  53. package/dist/esm/__test__/rollback.test.d.ts +1 -0
  54. package/dist/esm/__test__/rollback.test.js +194 -0
  55. package/dist/esm/__test__/rollback.test.js.map +1 -0
  56. package/dist/esm/client.d.ts +2 -2
  57. package/dist/esm/client.js +14 -6
  58. package/dist/esm/client.js.map +1 -1
  59. package/dist/esm/errors.d.ts +13 -1
  60. package/dist/esm/errors.js +10 -0
  61. package/dist/esm/errors.js.map +1 -1
  62. package/dist/esm/in-memory/document-client.d.ts +45 -0
  63. package/dist/esm/in-memory/document-client.js +791 -0
  64. package/dist/esm/in-memory/document-client.js.map +1 -0
  65. package/dist/esm/in-memory/expression.d.ts +42 -0
  66. package/dist/esm/in-memory/expression.js +577 -0
  67. package/dist/esm/in-memory/expression.js.map +1 -0
  68. package/dist/esm/in-memory/index.d.ts +2 -0
  69. package/dist/esm/in-memory/index.js +3 -0
  70. package/dist/esm/in-memory/index.js.map +1 -0
  71. package/dist/esm/in-memory/spec.d.ts +23 -0
  72. package/dist/esm/in-memory/spec.js +138 -0
  73. package/dist/esm/in-memory/spec.js.map +1 -0
  74. package/dist/esm/in-memory/store.d.ts +73 -0
  75. package/dist/esm/in-memory/store.js +258 -0
  76. package/dist/esm/in-memory/store.js.map +1 -0
  77. package/dist/esm/in-memory/treap.d.ts +31 -0
  78. package/dist/esm/in-memory/treap.js +183 -0
  79. package/dist/esm/in-memory/treap.js.map +1 -0
  80. package/dist/esm/in-memory/utils.d.ts +10 -0
  81. package/dist/esm/in-memory/utils.js +28 -0
  82. package/dist/esm/in-memory/utils.js.map +1 -0
  83. package/dist/esm/sandbox.d.ts +2 -0
  84. package/dist/esm/sandbox.js +172 -1
  85. package/dist/esm/sandbox.js.map +1 -1
  86. package/package.json +2 -1
  87. package/src/__test__/client-env-guard.test.ts +31 -0
  88. package/src/__test__/conformance.test.ts +2042 -0
  89. package/src/__test__/in-memory.spec.test.ts +230 -0
  90. package/src/__test__/rollback.test.ts +279 -0
  91. package/src/client.ts +17 -4
  92. package/src/errors.ts +24 -0
  93. package/src/in-memory/document-client.ts +1140 -0
  94. package/src/in-memory/expression.ts +730 -0
  95. package/src/in-memory/index.ts +2 -0
  96. package/src/in-memory/spec.ts +159 -0
  97. package/src/in-memory/store.ts +360 -0
  98. package/src/in-memory/treap.ts +239 -0
  99. package/src/in-memory/utils.ts +45 -0
  100. 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
+ }