cmp-aws-database 1.7.1-dev.27 → 1.7.1-dev.29

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.
@@ -12,15 +12,32 @@ type DynamooseModelLike = {
12
12
  export declare class GenericDynamooseDAO<T extends BaseDynamooseModel> {
13
13
  protected readonly model: DynamooseModelLike;
14
14
  protected readonly primaryKeyName: keyof T & string;
15
+ protected readonly sortKeyName?: (keyof T & string) | undefined;
15
16
  /**
16
17
  * @param model Dynamoose model instance for the target table.
17
18
  * @param primaryKeyName Attribute name used as the table hash key.
18
19
  */
19
- constructor(model: DynamooseModelLike, primaryKeyName: keyof T & string);
20
+ constructor(model: DynamooseModelLike, primaryKeyName: keyof T & string, sortKeyName?: (keyof T & string) | undefined);
20
21
  /**
21
22
  * Builds a DynamoDB key object from a single primary key value.
22
23
  */
23
- protected getKeyObject(primaryKeyValue: string): DynamoKey;
24
+ protected getKeyObject(primaryKeyValue: string, sortKeyValue?: string): DynamoKey;
25
+ /**
26
+ * Extracts and validates string primary key value from an item.
27
+ */
28
+ protected getPrimaryKeyValueFromItem(item: T): string;
29
+ /**
30
+ * Extracts and validates sort key value from an item when sort key is configured.
31
+ */
32
+ protected getSortKeyValueFromItem(item: T): string | undefined;
33
+ /**
34
+ * Builds complete key object (hash + optional sort) from an item.
35
+ */
36
+ protected getItemKeyObject(item: T): DynamoKey;
37
+ /**
38
+ * Serializes key object for stable set/map comparisons.
39
+ */
40
+ protected serializeKey(key: DynamoKey): string;
24
41
  /**
25
42
  * Creates a new record and automatically stamps created audit fields.
26
43
  */
@@ -28,23 +45,32 @@ export declare class GenericDynamooseDAO<T extends BaseDynamooseModel> {
28
45
  /**
29
46
  * Updates an existing record and automatically stamps updated audit fields.
30
47
  */
31
- update(primaryKeyValue: string, updates: Partial<T>, authContext?: AuthContext): Promise<T>;
48
+ update(primaryKeyValue: string, updates: Partial<T>, authContext?: AuthContext, sortKeyValue?: string): Promise<T>;
32
49
  /**
33
50
  * Deletes one record by primary key.
34
51
  */
35
- delete(primaryKeyValue: string): Promise<T | undefined>;
52
+ delete(primaryKeyValue: string, sortKeyValue?: string): Promise<T | undefined>;
36
53
  /**
37
54
  * Fetches one record by primary key. Returns null when not found.
38
55
  */
39
- get(primaryKeyValue: string): Promise<T | null>;
56
+ get(primaryKeyValue: string, sortKeyValue?: string): Promise<T | null>;
40
57
  /**
41
58
  * Writes multiple records in a batch and throws if any item is left unprocessed.
42
59
  */
43
60
  batchSave(items: T[], authContext?: AuthContext): Promise<T[]>;
61
+ /**
62
+ * Upserts multiple records by primary key.
63
+ * New keys are created (created_* fields), existing keys are updated (updated_* fields).
64
+ */
65
+ batchUpsert(items: T[], authContext?: AuthContext): Promise<T[]>;
44
66
  /**
45
67
  * Fetches multiple records by primary keys.
46
68
  */
47
69
  batchGet(primaryKeyValues: string[]): Promise<T[]>;
70
+ /**
71
+ * Fetches multiple records by key objects (supports hash + optional sort key).
72
+ */
73
+ batchGetByKeys(keys: DynamoKey[]): Promise<T[]>;
48
74
  /**
49
75
  * Decodes a base64 continuation token into DynamoDB last evaluated key.
50
76
  */
@@ -6,15 +6,65 @@ class GenericDynamooseDAO {
6
6
  * @param model Dynamoose model instance for the target table.
7
7
  * @param primaryKeyName Attribute name used as the table hash key.
8
8
  */
9
- constructor(model, primaryKeyName) {
9
+ constructor(model, primaryKeyName, sortKeyName) {
10
10
  this.model = model;
11
11
  this.primaryKeyName = primaryKeyName;
12
+ this.sortKeyName = sortKeyName;
12
13
  }
13
14
  /**
14
15
  * Builds a DynamoDB key object from a single primary key value.
15
16
  */
16
- getKeyObject(primaryKeyValue) {
17
- return { [this.primaryKeyName]: primaryKeyValue };
17
+ getKeyObject(primaryKeyValue, sortKeyValue) {
18
+ const keyObject = { [this.primaryKeyName]: primaryKeyValue };
19
+ if (this.sortKeyName) {
20
+ if (!sortKeyValue) {
21
+ throw new Error(`Missing sort key value for '${this.sortKeyName}'`);
22
+ }
23
+ keyObject[this.sortKeyName] = sortKeyValue;
24
+ }
25
+ return keyObject;
26
+ }
27
+ /**
28
+ * Extracts and validates string primary key value from an item.
29
+ */
30
+ getPrimaryKeyValueFromItem(item) {
31
+ const keyRecord = item;
32
+ const keyValue = keyRecord[this.primaryKeyName];
33
+ if (typeof keyValue !== "string" || keyValue.length === 0) {
34
+ throw new Error(`Missing or invalid primary key value for '${this.primaryKeyName}'`);
35
+ }
36
+ return keyValue;
37
+ }
38
+ /**
39
+ * Extracts and validates sort key value from an item when sort key is configured.
40
+ */
41
+ getSortKeyValueFromItem(item) {
42
+ if (!this.sortKeyName) {
43
+ return undefined;
44
+ }
45
+ const keyRecord = item;
46
+ const keyValue = keyRecord[this.sortKeyName];
47
+ if (typeof keyValue !== "string" || keyValue.length === 0) {
48
+ throw new Error(`Missing or invalid sort key value for '${this.sortKeyName}'`);
49
+ }
50
+ return keyValue;
51
+ }
52
+ /**
53
+ * Builds complete key object (hash + optional sort) from an item.
54
+ */
55
+ getItemKeyObject(item) {
56
+ const primaryKeyValue = this.getPrimaryKeyValueFromItem(item);
57
+ const sortKeyValue = this.getSortKeyValueFromItem(item);
58
+ return this.getKeyObject(primaryKeyValue, sortKeyValue);
59
+ }
60
+ /**
61
+ * Serializes key object for stable set/map comparisons.
62
+ */
63
+ serializeKey(key) {
64
+ if (!this.sortKeyName) {
65
+ return `${key[this.primaryKeyName]}`;
66
+ }
67
+ return `${key[this.primaryKeyName]}#${key[this.sortKeyName]}`;
18
68
  }
19
69
  /**
20
70
  * Creates a new record and automatically stamps created audit fields.
@@ -31,9 +81,9 @@ class GenericDynamooseDAO {
31
81
  /**
32
82
  * Updates an existing record and automatically stamps updated audit fields.
33
83
  */
34
- async update(primaryKeyValue, updates, authContext) {
84
+ async update(primaryKeyValue, updates, authContext, sortKeyValue) {
35
85
  const updateFn = this.model.update;
36
- const updated = await updateFn(this.getKeyObject(primaryKeyValue), {
86
+ const updated = await updateFn(this.getKeyObject(primaryKeyValue, sortKeyValue), {
37
87
  ...updates,
38
88
  updated_time: new Date(),
39
89
  updated_user: authContext?.userSub
@@ -43,17 +93,17 @@ class GenericDynamooseDAO {
43
93
  /**
44
94
  * Deletes one record by primary key.
45
95
  */
46
- async delete(primaryKeyValue) {
96
+ async delete(primaryKeyValue, sortKeyValue) {
47
97
  const deleteFn = this.model.delete;
48
- const deleted = await deleteFn(this.getKeyObject(primaryKeyValue));
98
+ const deleted = await deleteFn(this.getKeyObject(primaryKeyValue, sortKeyValue));
49
99
  return deleted;
50
100
  }
51
101
  /**
52
102
  * Fetches one record by primary key. Returns null when not found.
53
103
  */
54
- async get(primaryKeyValue) {
104
+ async get(primaryKeyValue, sortKeyValue) {
55
105
  const getFn = this.model.get;
56
- const item = await getFn(this.getKeyObject(primaryKeyValue));
106
+ const item = await getFn(this.getKeyObject(primaryKeyValue, sortKeyValue));
57
107
  return item ?? null;
58
108
  }
59
109
  /**
@@ -73,11 +123,48 @@ class GenericDynamooseDAO {
73
123
  }
74
124
  return inputItems;
75
125
  }
126
+ /**
127
+ * Upserts multiple records by primary key.
128
+ * New keys are created (created_* fields), existing keys are updated (updated_* fields).
129
+ */
130
+ async batchUpsert(items, authContext) {
131
+ const now = new Date();
132
+ const keys = items.map((item) => this.getItemKeyObject(item));
133
+ const existingItems = await this.batchGetByKeys(keys);
134
+ const existingKeySet = new Set(existingItems.map((item) => this.serializeKey(this.getItemKeyObject(item))));
135
+ const upsertItems = items.map((item) => {
136
+ const itemKey = this.getItemKeyObject(item);
137
+ if (existingKeySet.has(this.serializeKey(itemKey))) {
138
+ return {
139
+ ...item,
140
+ updated_time: now,
141
+ updated_user: authContext?.userSub
142
+ };
143
+ }
144
+ return {
145
+ ...item,
146
+ created_time: now,
147
+ created_user: authContext?.userSub
148
+ };
149
+ });
150
+ const batchPutFn = this.model.batchPut;
151
+ const result = await batchPutFn(upsertItems);
152
+ if (result.unprocessedItems.length > 0) {
153
+ throw new Error(`Batch upsert partially failed. Unprocessed items: ${result.unprocessedItems.length}`);
154
+ }
155
+ return upsertItems;
156
+ }
76
157
  /**
77
158
  * Fetches multiple records by primary keys.
78
159
  */
79
160
  async batchGet(primaryKeyValues) {
80
161
  const keys = primaryKeyValues.map((value) => this.getKeyObject(value));
162
+ return this.batchGetByKeys(keys);
163
+ }
164
+ /**
165
+ * Fetches multiple records by key objects (supports hash + optional sort key).
166
+ */
167
+ async batchGetByKeys(keys) {
81
168
  const batchGetFn = this.model.batchGet;
82
169
  const items = await batchGetFn(keys);
83
170
  return items;
@@ -107,4 +194,4 @@ class GenericDynamooseDAO {
107
194
  }
108
195
  }
109
196
  exports.GenericDynamooseDAO = GenericDynamooseDAO;
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dynamoose-dao.js","sourceRoot":"","sources":["../src/base-dynamoose-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseDynamooseModel, AuthContext } from \"./base-dynamoose-model\";\n\ntype DynamoKeyValue = string | number | boolean | null;\nexport type DynamoKey = Record<string, DynamoKeyValue>;\n\ntype BatchPutResponse<T> = {\n    unprocessedItems: Partial<T>[];\n};\n\ntype CreateFn<T> = (item: Partial<T>) => Promise<object>;\ntype UpdateFn<T> = (key: DynamoKey, update: Partial<T>) => Promise<object>;\ntype DeleteFn = (key: DynamoKey) => Promise<object | undefined>;\ntype GetFn = (key: DynamoKey) => Promise<object | undefined>;\ntype BatchPutFn<T> = (items: Partial<T>[]) => Promise<BatchPutResponse<T>>;\ntype BatchGetFn = (keys: DynamoKey[]) => Promise<object[]>;\n\ntype DynamooseModelLike = {\n    create: Function;\n    update: Function;\n    get: Function;\n    delete: Function;\n    batchPut: Function;\n    batchGet: Function;\n};\n\nexport class GenericDynamooseDAO<T extends BaseDynamooseModel> {\n    /**\n     * @param model Dynamoose model instance for the target table.\n     * @param primaryKeyName Attribute name used as the table hash key.\n     */\n    constructor(\n        protected readonly model: DynamooseModelLike,\n        protected readonly primaryKeyName: keyof T & string\n    ) { }\n\n    /**\n     * Builds a DynamoDB key object from a single primary key value.\n     */\n    protected getKeyObject(primaryKeyValue: string): DynamoKey {\n        return { [this.primaryKeyName]: primaryKeyValue };\n    }\n\n    /**\n     * Creates a new record and automatically stamps created audit fields.\n     */\n    async save(item: T, authContext?: AuthContext): Promise<T> {\n        const createFn = this.model.create as CreateFn<T>;\n        const created = await createFn({\n            ...item,\n            created_time: new Date(),\n            created_user: authContext?.userSub\n        });\n        return created as T;\n    }\n\n    /**\n     * Updates an existing record and automatically stamps updated audit fields.\n     */\n    async update(primaryKeyValue: string, updates: Partial<T>, authContext?: AuthContext): Promise<T> {\n        const updateFn = this.model.update as UpdateFn<T>;\n        const updated = await updateFn(\n            this.getKeyObject(primaryKeyValue),\n            {\n                ...updates,\n                updated_time: new Date(),\n                updated_user: authContext?.userSub\n            }\n        );\n        return updated as T;\n    }\n\n    /**\n     * Deletes one record by primary key.\n     */\n    async delete(primaryKeyValue: string): Promise<T | undefined> {\n        const deleteFn = this.model.delete as DeleteFn;\n        const deleted = await deleteFn(this.getKeyObject(primaryKeyValue));\n        return deleted as T | undefined;\n    }\n\n    /**\n     * Fetches one record by primary key. Returns null when not found.\n     */\n    async get(primaryKeyValue: string): Promise<T | null> {\n        const getFn = this.model.get as GetFn;\n        const item = await getFn(this.getKeyObject(primaryKeyValue));\n        return (item as T | undefined) ?? null;\n    }\n\n    /**\n     * Writes multiple records in a batch and throws if any item is left unprocessed.\n     */\n    async batchSave(items: T[], authContext?: AuthContext): Promise<T[]> {\n        const now = new Date();\n        const inputItems = items.map((item) => ({\n            ...item,\n            created_time: now,\n            created_user: authContext?.userSub\n        })) as T[];\n\n        const batchPutFn = this.model.batchPut as BatchPutFn<T>;\n        const result = await batchPutFn(inputItems);\n        if (result.unprocessedItems.length > 0) {\n            throw new Error(`Batch save partially failed. Unprocessed items: ${result.unprocessedItems.length}`);\n        }\n\n        return inputItems;\n    }\n\n    /**\n     * Fetches multiple records by primary keys.\n     */\n    async batchGet(primaryKeyValues: string[]): Promise<T[]> {\n        const keys = primaryKeyValues.map((value) => this.getKeyObject(value));\n        const batchGetFn = this.model.batchGet as BatchGetFn;\n        const items = await batchGetFn(keys);\n        return items as T[];\n    }\n\n    /**\n     * Decodes a base64 continuation token into DynamoDB last evaluated key.\n     */\n    decode(continuationToken: string | undefined): DynamoKey | undefined {\n        if (!continuationToken) {\n            return undefined;\n        }\n\n        try {\n            return JSON.parse(Buffer.from(continuationToken, \"base64\").toString(\"utf8\")) as DynamoKey;\n        } catch (error) {\n            throw new Error(\"Invalid continuationToken\");\n        }\n    }\n\n    /**\n     * Encodes DynamoDB last evaluated key into a base64 continuation token.\n     */\n    async encode(lastEvaluatedKey: DynamoKey | undefined): Promise<string | undefined> {\n        if (!lastEvaluatedKey) {\n            return undefined;\n        }\n\n        return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString(\"base64\");\n    }\n}\n"]}
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dynamoose-dao.js","sourceRoot":"","sources":["../src/base-dynamoose-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseDynamooseModel, AuthContext } from \"./base-dynamoose-model\";\n\ntype DynamoKeyValue = string | number | boolean | null;\nexport type DynamoKey = Record<string, DynamoKeyValue>;\n\ntype BatchPutResponse<T> = {\n    unprocessedItems: Partial<T>[];\n};\n\ntype CreateFn<T> = (item: Partial<T>) => Promise<object>;\ntype UpdateFn<T> = (key: DynamoKey, update: Partial<T>) => Promise<object>;\ntype DeleteFn = (key: DynamoKey) => Promise<object | undefined>;\ntype GetFn = (key: DynamoKey) => Promise<object | undefined>;\ntype BatchPutFn<T> = (items: Partial<T>[]) => Promise<BatchPutResponse<T>>;\ntype BatchGetFn = (keys: DynamoKey[]) => Promise<object[]>;\n\ntype DynamooseModelLike = {\n    create: Function;\n    update: Function;\n    get: Function;\n    delete: Function;\n    batchPut: Function;\n    batchGet: Function;\n};\n\nexport class GenericDynamooseDAO<T extends BaseDynamooseModel> {\n    /**\n     * @param model Dynamoose model instance for the target table.\n     * @param primaryKeyName Attribute name used as the table hash key.\n     */\n    constructor(\n        protected readonly model: DynamooseModelLike,\n        protected readonly primaryKeyName: keyof T & string,\n        protected readonly sortKeyName?: keyof T & string\n    ) { }\n\n    /**\n     * Builds a DynamoDB key object from a single primary key value.\n     */\n    protected getKeyObject(primaryKeyValue: string, sortKeyValue?: string): DynamoKey {\n        const keyObject: DynamoKey = { [this.primaryKeyName]: primaryKeyValue };\n        if (this.sortKeyName) {\n            if (!sortKeyValue) {\n                throw new Error(`Missing sort key value for '${this.sortKeyName}'`);\n            }\n            keyObject[this.sortKeyName] = sortKeyValue;\n        }\n        return keyObject;\n    }\n\n    /**\n     * Extracts and validates string primary key value from an item.\n     */\n    protected getPrimaryKeyValueFromItem(item: T): string {\n        const keyRecord = item as unknown as Record<string, DynamoKeyValue | undefined>;\n        const keyValue = keyRecord[this.primaryKeyName];\n        if (typeof keyValue !== \"string\" || keyValue.length === 0) {\n            throw new Error(`Missing or invalid primary key value for '${this.primaryKeyName}'`);\n        }\n        return keyValue;\n    }\n\n    /**\n     * Extracts and validates sort key value from an item when sort key is configured.\n     */\n    protected getSortKeyValueFromItem(item: T): string | undefined {\n        if (!this.sortKeyName) {\n            return undefined;\n        }\n        const keyRecord = item as unknown as Record<string, DynamoKeyValue | undefined>;\n        const keyValue = keyRecord[this.sortKeyName];\n        if (typeof keyValue !== \"string\" || keyValue.length === 0) {\n            throw new Error(`Missing or invalid sort key value for '${this.sortKeyName}'`);\n        }\n        return keyValue;\n    }\n\n    /**\n     * Builds complete key object (hash + optional sort) from an item.\n     */\n    protected getItemKeyObject(item: T): DynamoKey {\n        const primaryKeyValue = this.getPrimaryKeyValueFromItem(item);\n        const sortKeyValue = this.getSortKeyValueFromItem(item);\n        return this.getKeyObject(primaryKeyValue, sortKeyValue);\n    }\n\n    /**\n     * Serializes key object for stable set/map comparisons.\n     */\n    protected serializeKey(key: DynamoKey): string {\n        if (!this.sortKeyName) {\n            return `${key[this.primaryKeyName]}`;\n        }\n        return `${key[this.primaryKeyName]}#${key[this.sortKeyName]}`;\n    }\n\n    /**\n     * Creates a new record and automatically stamps created audit fields.\n     */\n    async save(item: T, authContext?: AuthContext): Promise<T> {\n        const createFn = this.model.create as CreateFn<T>;\n        const created = await createFn({\n            ...item,\n            created_time: new Date(),\n            created_user: authContext?.userSub\n        });\n        return created as T;\n    }\n\n    /**\n     * Updates an existing record and automatically stamps updated audit fields.\n     */\n    async update(primaryKeyValue: string, updates: Partial<T>, authContext?: AuthContext, sortKeyValue?: string): Promise<T> {\n        const updateFn = this.model.update as UpdateFn<T>;\n        const updated = await updateFn(\n            this.getKeyObject(primaryKeyValue, sortKeyValue),\n            {\n                ...updates,\n                updated_time: new Date(),\n                updated_user: authContext?.userSub\n            }\n        );\n        return updated as T;\n    }\n\n    /**\n     * Deletes one record by primary key.\n     */\n    async delete(primaryKeyValue: string, sortKeyValue?: string): Promise<T | undefined> {\n        const deleteFn = this.model.delete as DeleteFn;\n        const deleted = await deleteFn(this.getKeyObject(primaryKeyValue, sortKeyValue));\n        return deleted as T | undefined;\n    }\n\n    /**\n     * Fetches one record by primary key. Returns null when not found.\n     */\n    async get(primaryKeyValue: string, sortKeyValue?: string): Promise<T | null> {\n        const getFn = this.model.get as GetFn;\n        const item = await getFn(this.getKeyObject(primaryKeyValue, sortKeyValue));\n        return (item as T | undefined) ?? null;\n    }\n\n    /**\n     * Writes multiple records in a batch and throws if any item is left unprocessed.\n     */\n    async batchSave(items: T[], authContext?: AuthContext): Promise<T[]> {\n        const now = new Date();\n        const inputItems = items.map((item) => ({\n            ...item,\n            created_time: now,\n            created_user: authContext?.userSub\n        })) as T[];\n\n        const batchPutFn = this.model.batchPut as BatchPutFn<T>;\n        const result = await batchPutFn(inputItems);\n        if (result.unprocessedItems.length > 0) {\n            throw new Error(`Batch save partially failed. Unprocessed items: ${result.unprocessedItems.length}`);\n        }\n\n        return inputItems;\n    }\n\n    /**\n     * Upserts multiple records by primary key.\n     * New keys are created (created_* fields), existing keys are updated (updated_* fields).\n     */\n    async batchUpsert(items: T[], authContext?: AuthContext): Promise<T[]> {\n        const now = new Date();\n        const keys = items.map((item) => this.getItemKeyObject(item));\n        const existingItems = await this.batchGetByKeys(keys);\n\n        const existingKeySet = new Set(\n            existingItems.map((item) => this.serializeKey(this.getItemKeyObject(item)))\n        );\n\n        const upsertItems = items.map((item) => {\n            const itemKey = this.getItemKeyObject(item);\n            if (existingKeySet.has(this.serializeKey(itemKey))) {\n                return {\n                    ...item,\n                    updated_time: now,\n                    updated_user: authContext?.userSub\n                };\n            }\n\n            return {\n                ...item,\n                created_time: now,\n                created_user: authContext?.userSub\n            };\n        }) as T[];\n\n        const batchPutFn = this.model.batchPut as BatchPutFn<T>;\n        const result = await batchPutFn(upsertItems);\n        if (result.unprocessedItems.length > 0) {\n            throw new Error(`Batch upsert partially failed. Unprocessed items: ${result.unprocessedItems.length}`);\n        }\n\n        return upsertItems;\n    }\n\n    /**\n     * Fetches multiple records by primary keys.\n     */\n    async batchGet(primaryKeyValues: string[]): Promise<T[]> {\n        const keys = primaryKeyValues.map((value) => this.getKeyObject(value));\n        return this.batchGetByKeys(keys);\n    }\n\n    /**\n     * Fetches multiple records by key objects (supports hash + optional sort key).\n     */\n    async batchGetByKeys(keys: DynamoKey[]): Promise<T[]> {\n        const batchGetFn = this.model.batchGet as BatchGetFn;\n        const items = await batchGetFn(keys);\n        return items as T[];\n    }\n\n    /**\n     * Decodes a base64 continuation token into DynamoDB last evaluated key.\n     */\n    decode(continuationToken: string | undefined): DynamoKey | undefined {\n        if (!continuationToken) {\n            return undefined;\n        }\n\n        try {\n            return JSON.parse(Buffer.from(continuationToken, \"base64\").toString(\"utf8\")) as DynamoKey;\n        } catch (error) {\n            throw new Error(\"Invalid continuationToken\");\n        }\n    }\n\n    /**\n     * Encodes DynamoDB last evaluated key into a base64 continuation token.\n     */\n    async encode(lastEvaluatedKey: DynamoKey | undefined): Promise<string | undefined> {\n        if (!lastEvaluatedKey) {\n            return undefined;\n        }\n\n        return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString(\"base64\");\n    }\n}\n"]}
@@ -1,13 +1,20 @@
1
+ import { Item } from "dynamoose/dist/Item";
1
2
  /**
2
- * Shared audit fields for Dynamoose entities.
3
- * Extend this interface in module-specific model interfaces.
3
+ * Shared audit fields contract for Dynamoose entities.
4
+ * Combine with `Item` so module models satisfy Dynamoose generic constraints.
4
5
  */
5
- export interface BaseDynamooseModel {
6
+ export interface BaseDynamooseFields {
6
7
  created_time?: Date;
7
8
  updated_time?: Date;
8
9
  created_user?: string;
9
10
  updated_user?: string;
10
11
  }
12
+ /**
13
+ * Base Dynamoose model that all module models should extend.
14
+ * Provides Dynamoose Item methods plus shared audit fields.
15
+ */
16
+ export interface BaseDynamooseModel extends Item, BaseDynamooseFields {
17
+ }
11
18
  /**
12
19
  * Reusable runtime schema fragment for audit fields.
13
20
  * Spread this into Dynamoose schema definitions to avoid duplication.
@@ -11,4 +11,4 @@ exports.BASE_DYNAMOOSE_AUDIT_SCHEMA = {
11
11
  created_user: String,
12
12
  updated_user: String
13
13
  };
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1keW5hbW9vc2UtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYmFzZS1keW5hbW9vc2UtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBV0E7OztHQUdHO0FBQ1UsUUFBQSwyQkFBMkIsR0FBRztJQUN2QyxZQUFZLEVBQUUsSUFBSTtJQUNsQixZQUFZLEVBQUUsSUFBSTtJQUNsQixZQUFZLEVBQUUsTUFBTTtJQUNwQixZQUFZLEVBQUUsTUFBTTtDQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNoYXJlZCBhdWRpdCBmaWVsZHMgZm9yIER5bmFtb29zZSBlbnRpdGllcy5cbiAqIEV4dGVuZCB0aGlzIGludGVyZmFjZSBpbiBtb2R1bGUtc3BlY2lmaWMgbW9kZWwgaW50ZXJmYWNlcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCYXNlRHluYW1vb3NlTW9kZWwge1xuICAgIGNyZWF0ZWRfdGltZT86IERhdGU7XG4gICAgdXBkYXRlZF90aW1lPzogRGF0ZTtcbiAgICBjcmVhdGVkX3VzZXI/OiBzdHJpbmc7XG4gICAgdXBkYXRlZF91c2VyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFJldXNhYmxlIHJ1bnRpbWUgc2NoZW1hIGZyYWdtZW50IGZvciBhdWRpdCBmaWVsZHMuXG4gKiBTcHJlYWQgdGhpcyBpbnRvIER5bmFtb29zZSBzY2hlbWEgZGVmaW5pdGlvbnMgdG8gYXZvaWQgZHVwbGljYXRpb24uXG4gKi9cbmV4cG9ydCBjb25zdCBCQVNFX0RZTkFNT09TRV9BVURJVF9TQ0hFTUEgPSB7XG4gICAgY3JlYXRlZF90aW1lOiBEYXRlLFxuICAgIHVwZGF0ZWRfdGltZTogRGF0ZSxcbiAgICBjcmVhdGVkX3VzZXI6IFN0cmluZyxcbiAgICB1cGRhdGVkX3VzZXI6IFN0cmluZ1xufSBhcyBjb25zdDtcblxuLyoqXG4gKiBBdXRoIHBheWxvYWQgdXNlZCBieSBEQU8gbWV0aG9kcyBmb3IgYXVkaXQgc3RhbXBpbmcuXG4gKi9cbmV4cG9ydCB0eXBlIEF1dGhDb250ZXh0ID0ge1xuICAgIHVzZXJTdWI/OiBzdHJpbmc7XG59O1xuIl19
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1keW5hbW9vc2UtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYmFzZS1keW5hbW9vc2UtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBbUJBOzs7R0FHRztBQUNVLFFBQUEsMkJBQTJCLEdBQUc7SUFDdkMsWUFBWSxFQUFFLElBQUk7SUFDbEIsWUFBWSxFQUFFLElBQUk7SUFDbEIsWUFBWSxFQUFFLE1BQU07SUFDcEIsWUFBWSxFQUFFLE1BQU07Q0FDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSXRlbSB9IGZyb20gXCJkeW5hbW9vc2UvZGlzdC9JdGVtXCI7XG5cbi8qKlxuICogU2hhcmVkIGF1ZGl0IGZpZWxkcyBjb250cmFjdCBmb3IgRHluYW1vb3NlIGVudGl0aWVzLlxuICogQ29tYmluZSB3aXRoIGBJdGVtYCBzbyBtb2R1bGUgbW9kZWxzIHNhdGlzZnkgRHluYW1vb3NlIGdlbmVyaWMgY29uc3RyYWludHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUR5bmFtb29zZUZpZWxkcyB7XG4gICAgY3JlYXRlZF90aW1lPzogRGF0ZTtcbiAgICB1cGRhdGVkX3RpbWU/OiBEYXRlO1xuICAgIGNyZWF0ZWRfdXNlcj86IHN0cmluZztcbiAgICB1cGRhdGVkX3VzZXI/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQmFzZSBEeW5hbW9vc2UgbW9kZWwgdGhhdCBhbGwgbW9kdWxlIG1vZGVscyBzaG91bGQgZXh0ZW5kLlxuICogUHJvdmlkZXMgRHluYW1vb3NlIEl0ZW0gbWV0aG9kcyBwbHVzIHNoYXJlZCBhdWRpdCBmaWVsZHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUR5bmFtb29zZU1vZGVsIGV4dGVuZHMgSXRlbSwgQmFzZUR5bmFtb29zZUZpZWxkcyB7IH1cblxuLyoqXG4gKiBSZXVzYWJsZSBydW50aW1lIHNjaGVtYSBmcmFnbWVudCBmb3IgYXVkaXQgZmllbGRzLlxuICogU3ByZWFkIHRoaXMgaW50byBEeW5hbW9vc2Ugc2NoZW1hIGRlZmluaXRpb25zIHRvIGF2b2lkIGR1cGxpY2F0aW9uLlxuICovXG5leHBvcnQgY29uc3QgQkFTRV9EWU5BTU9PU0VfQVVESVRfU0NIRU1BID0ge1xuICAgIGNyZWF0ZWRfdGltZTogRGF0ZSxcbiAgICB1cGRhdGVkX3RpbWU6IERhdGUsXG4gICAgY3JlYXRlZF91c2VyOiBTdHJpbmcsXG4gICAgdXBkYXRlZF91c2VyOiBTdHJpbmdcbn0gYXMgY29uc3Q7XG5cbi8qKlxuICogQXV0aCBwYXlsb2FkIHVzZWQgYnkgREFPIG1ldGhvZHMgZm9yIGF1ZGl0IHN0YW1waW5nLlxuICovXG5leHBvcnQgdHlwZSBBdXRoQ29udGV4dCA9IHtcbiAgICB1c2VyU3ViPzogc3RyaW5nO1xufTtcbiJdfQ==
@@ -1,6 +1,6 @@
1
1
  import { GenericDynamooseDAO } from "../../base-dynamoose-dao";
2
2
  import { AuthContext } from "../../base-dynamoose-model";
3
- import { CreatePlatterFitInput, PlatterFit } from "./platter-fit-model";
3
+ import { PlatterFit } from "./platter-fit-model";
4
4
  type ListResult = {
5
5
  items: PlatterFit[];
6
6
  nextToken?: string;
@@ -14,7 +14,7 @@ declare class PlatterFitDao extends GenericDynamooseDAO<PlatterFit> {
14
14
  * Creates one platter-fit record.
15
15
  * If platterFitId is not passed, Dynamoose auto-generates it from schema default.
16
16
  */
17
- save: (item: CreatePlatterFitInput, authContext?: AuthContext) => Promise<PlatterFit>;
17
+ save: (item: PlatterFit, authContext?: AuthContext) => Promise<PlatterFit>;
18
18
  /**
19
19
  * Updates one platter-fit record by id with conditional existence check.
20
20
  */
@@ -76,7 +76,7 @@ class PlatterFitDao extends base_dynamoose_dao_1.GenericDynamooseDAO {
76
76
  }
77
77
  const queryResult = await queryBuilder.exec();
78
78
  return {
79
- items: queryResult.map((item) => ({ ...item })),
79
+ items: queryResult,
80
80
  nextToken: await this.encode(queryResult.lastKey)
81
81
  };
82
82
  };
@@ -97,11 +97,11 @@ class PlatterFitDao extends base_dynamoose_dao_1.GenericDynamooseDAO {
97
97
  }
98
98
  const queryResult = await queryBuilder.exec();
99
99
  return {
100
- items: queryResult.map((item) => ({ ...item })),
100
+ items: queryResult,
101
101
  nextToken: await this.encode(queryResult.lastKey)
102
102
  };
103
103
  };
104
104
  }
105
105
  }
106
106
  exports.platterFitDao = new PlatterFitDao();
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"platter-fit-dao.js","sourceRoot":"","sources":["../../../src/customer-user/platter-fit-module/platter-fit-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import dynamoose from \"dynamoose\";\nimport { DynamoKey, GenericDynamooseDAO } from \"../../base-dynamoose-dao\";\nimport { AuthContext } from \"../../base-dynamoose-model\";\nimport { CreatePlatterFitInput, PlatterFit, PlatterFitModel } from \"./platter-fit-model\";\n\ntype ListResult = {\n    items: PlatterFit[];\n    nextToken?: string;\n};\n\nclass PlatterFitDao extends GenericDynamooseDAO<PlatterFit> {\n    /**\n     * Connects platter-fit DAO to the table model and its primary key.\n     */\n    constructor() {\n        super(PlatterFitModel, \"platterFitId\");\n    }\n\n    /**\n     * Creates one platter-fit record.\n     * If platterFitId is not passed, Dynamoose auto-generates it from schema default.\n     */\n    save = async (item: CreatePlatterFitInput, authContext?: AuthContext): Promise<PlatterFit> => {\n        return super.save(item as PlatterFit, authContext);\n    };\n\n    /**\n     * Updates one platter-fit record by id with conditional existence check.\n     */\n    update = async (\n        platterFitId: string,\n        updates: Partial<PlatterFit>,\n        authContext?: AuthContext\n    ): Promise<PlatterFit> => {\n        const updated = await PlatterFitModel.update(\n            { platterFitId },\n            {\n                ...updates,\n                updated_time: new Date(),\n                updated_user: authContext?.userSub\n            },\n            {\n                condition: new dynamoose.Condition().where(\"platterFitId\").eq(platterFitId)\n            }\n        );\n        return { ...(updated as object) } as PlatterFit;\n    };\n\n    /**\n     * Returns one platter-fit record by primary key.\n     */\n    getById = async (platterFitId: string): Promise<PlatterFit | null> => this.get(platterFitId);\n\n    /**\n     * Lists records by status using token-based pagination.\n     * Pass returned nextToken in the next call to continue.\n     */\n    listByStatus = async (status: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"status\")\n            .eq(status)\n            .using(\"statusIndex\");\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult.map((item) => ({ ...(item as object) } as PlatterFit)),\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n\n    /**\n     * Lists records by occasionType using token-based pagination.\n     */\n    listByOccasionType = async (occasionType: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"occasionType\")\n            .eq(occasionType)\n            .using(\"occasionTypeIndex\");\n\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult.map((item) => ({ ...(item as object) } as PlatterFit)),\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n\n    /**\n     * Lists records by platterId using token-based pagination.\n     */\n    listByPlatterId = async (platterId: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"platterId\")\n            .eq(platterId)\n            .using(\"platterIdIndex\");\n\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult.map((item) => ({ ...(item as object) } as PlatterFit)),\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n}\n\nexport const platterFitDao = new PlatterFitDao();\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"platter-fit-dao.js","sourceRoot":"","sources":["../../../src/customer-user/platter-fit-module/platter-fit-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import dynamoose from \"dynamoose\";\nimport { DynamoKey, GenericDynamooseDAO } from \"../../base-dynamoose-dao\";\nimport { AuthContext } from \"../../base-dynamoose-model\";\nimport { PlatterFit, PlatterFitModel } from \"./platter-fit-model\";\n\ntype ListResult = {\n    items: PlatterFit[];\n    nextToken?: string;\n};\n\nclass PlatterFitDao extends GenericDynamooseDAO<PlatterFit> {\n    /**\n     * Connects platter-fit DAO to the table model and its primary key.\n     */\n    constructor() {\n        super(PlatterFitModel, \"platterFitId\");\n    }\n\n    /**\n     * Creates one platter-fit record.\n     * If platterFitId is not passed, Dynamoose auto-generates it from schema default.\n     */\n    save = async (item: PlatterFit, authContext?: AuthContext): Promise<PlatterFit> => {\n        return super.save(item, authContext);\n    };\n\n    /**\n     * Updates one platter-fit record by id with conditional existence check.\n     */\n    update = async (\n        platterFitId: string,\n        updates: Partial<PlatterFit>,\n        authContext?: AuthContext\n    ): Promise<PlatterFit> => {\n        const updated = await PlatterFitModel.update(\n            { platterFitId },\n            {\n                ...updates,\n                updated_time: new Date(),\n                updated_user: authContext?.userSub\n            },\n            {\n                condition: new dynamoose.Condition().where(\"platterFitId\").eq(platterFitId)\n            }\n        );\n        return { ...(updated as object) } as PlatterFit;\n    };\n\n    /**\n     * Returns one platter-fit record by primary key.\n     */\n    getById = async (platterFitId: string): Promise<PlatterFit | null> => this.get(platterFitId);\n\n    /**\n     * Lists records by status using token-based pagination.\n     * Pass returned nextToken in the next call to continue.\n     */\n    listByStatus = async (status: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"status\")\n            .eq(status)\n            .using(\"statusIndex\");\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult.map((item) => ({ ...(item as object) } as PlatterFit)),\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n\n    /**\n     * Lists records by occasionType using token-based pagination.\n     */\n    listByOccasionType = async (occasionType: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"occasionType\")\n            .eq(occasionType)\n            .using(\"occasionTypeIndex\");\n\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult as PlatterFit[],\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n\n    /**\n     * Lists records by platterId using token-based pagination.\n     */\n    listByPlatterId = async (platterId: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"platterId\")\n            .eq(platterId)\n            .using(\"platterIdIndex\");\n\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult,\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n}\n\nexport const platterFitDao = new PlatterFitDao();\n"]}
@@ -20,4 +20,9 @@ export interface PlatterFit extends BaseDynamooseModel {
20
20
  export type CreatePlatterFitInput = Omit<PlatterFit, "platterFitId"> & {
21
21
  platterFitId?: string;
22
22
  };
23
- export declare const PlatterFitModel: import("dynamoose/dist/General").ModelType<import("dynamoose/dist/Item").AnyItem>;
23
+ export declare const PlatterFitModel: import("dynamoose/dist/General").ModelType<PlatterFit>;
24
+ /**
25
+ * Converts a plain platter-fit payload into a Dynamoose model instance.
26
+ * Use this before persistence when you want model-level normalization.
27
+ */
28
+ export declare const convertToPlatterFitModel: (platterFit: CreatePlatterFitInput | PlatterFit) => PlatterFit;
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.PlatterFitModel = exports.PLATTER_FIT_TABLE_NAME = void 0;
6
+ exports.convertToPlatterFitModel = exports.PlatterFitModel = exports.PLATTER_FIT_TABLE_NAME = void 0;
7
7
  const dynamoose_1 = __importDefault(require("dynamoose"));
8
8
  const crypto_1 = require("crypto");
9
9
  const base_dynamoose_model_1 = require("../../base-dynamoose-model");
@@ -72,8 +72,13 @@ const platterFitSchema = new dynamoose_1.default.Schema({
72
72
  }, {
73
73
  saveUnknown: false
74
74
  });
75
- exports.PlatterFitModel = dynamoose_1.default.model(exports.PLATTER_FIT_TABLE_NAME, platterFitSchema, {
76
- create: false,
77
- waitForActive: false
78
- });
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdHRlci1maXQtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VzdG9tZXItdXNlci9wbGF0dGVyLWZpdC1tb2R1bGUvcGxhdHRlci1maXQtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsMERBQWtDO0FBQ2xDLG1DQUFvQztBQUNwQyxxRUFBNkY7QUFFaEYsUUFBQSxzQkFBc0IsR0FBRyxpQkFBaUIsQ0FBQztBQXdCeEQsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLG1CQUFTLENBQUMsTUFBTSxDQUN6QztJQUNJLFlBQVksRUFBRTtRQUNWLElBQUksRUFBRSxNQUFNO1FBQ1osT0FBTyxFQUFFLElBQUk7UUFDYixRQUFRLEVBQUUsSUFBSTtRQUNkLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFBLG1CQUFVLEdBQUU7S0FDOUI7SUFDRCxZQUFZLEVBQUU7UUFDVixJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0QsWUFBWSxFQUFFO1FBQ1YsSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRTtZQUNILElBQUksRUFBRSxtQkFBbUI7WUFDekIsSUFBSSxFQUFFLFFBQVE7U0FDakI7S0FDSjtJQUNELGVBQWUsRUFBRSxNQUFNO0lBQ3ZCLE1BQU0sRUFBRTtRQUNKLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7S0FDakI7SUFDRCxNQUFNLEVBQUU7UUFDSixJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0QsVUFBVSxFQUFFO1FBQ1IsSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtLQUNqQjtJQUNELElBQUksRUFBRTtRQUNGLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7S0FDakI7SUFDRCxPQUFPLEVBQUUsTUFBTTtJQUNmLFNBQVMsRUFBRTtRQUNQLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7UUFDZCxLQUFLLEVBQUU7WUFDSCxJQUFJLEVBQUUsZ0JBQWdCO1lBQ3RCLElBQUksRUFBRSxRQUFRO1NBQ2pCO0tBQ0o7SUFDRCxXQUFXLEVBQUU7UUFDVCxJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0Qsb0JBQW9CLEVBQUUsTUFBTTtJQUM1QixtQkFBbUIsRUFBRSxNQUFNO0lBQzNCLGlCQUFpQixFQUFFLE1BQU07SUFDekIsTUFBTSxFQUFFO1FBQ0osSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRTtZQUNILElBQUksRUFBRSxhQUFhO1lBQ25CLElBQUksRUFBRSxRQUFRO1NBQ2pCO0tBQ0o7SUFDRCxHQUFHLGtEQUEyQjtDQUNqQyxFQUNEO0lBQ0ksV0FBVyxFQUFFLEtBQUs7Q0FDckIsQ0FDSixDQUFDO0FBRVcsUUFBQSxlQUFlLEdBQUcsbUJBQVMsQ0FBQyxLQUFLLENBQzFDLDhCQUFzQixFQUN0QixnQkFBZ0IsRUFDaEI7SUFDSSxNQUFNLEVBQUUsS0FBSztJQUNiLGFBQWEsRUFBRSxLQUFLO0NBQ3ZCLENBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkeW5hbW9vc2UgZnJvbSBcImR5bmFtb29zZVwiO1xuaW1wb3J0IHsgcmFuZG9tVVVJRCB9IGZyb20gXCJjcnlwdG9cIjtcbmltcG9ydCB7IEJBU0VfRFlOQU1PT1NFX0FVRElUX1NDSEVNQSwgQmFzZUR5bmFtb29zZU1vZGVsIH0gZnJvbSBcIi4uLy4uL2Jhc2UtZHluYW1vb3NlLW1vZGVsXCI7XG5cbmV4cG9ydCBjb25zdCBQTEFUVEVSX0ZJVF9UQUJMRV9OQU1FID0gXCJQbGF0dGVyRml0VGFibGVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQbGF0dGVyRml0IGV4dGVuZHMgQmFzZUR5bmFtb29zZU1vZGVsIHtcbiAgICBwbGF0dGVyRml0SWQ6IHN0cmluZztcbiAgICBvY2Nhc2lvbk5hbWU6IHN0cmluZztcbiAgICBvY2Nhc2lvblR5cGU6IHN0cmluZztcbiAgICBvY2Nhc2lvblN1YlR5cGU/OiBzdHJpbmc7XG4gICAgbWluUGF4OiBudW1iZXI7XG4gICAgbWF4UGF4OiBudW1iZXI7XG4gICAgYnVkZ2V0VGllcjogc3RyaW5nO1xuICAgIHJhbms6IG51bWJlcjtcbiAgICByYW5rVGFnPzogc3RyaW5nO1xuICAgIHBsYXR0ZXJJZDogc3RyaW5nO1xuICAgIHBsYXR0ZXJOYW1lOiBzdHJpbmc7XG4gICAgYnVja2V0UGF4RGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gICAgb2NjYXNpb25EZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBvdGhlcnNEZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBzdGF0dXM6IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgQ3JlYXRlUGxhdHRlckZpdElucHV0ID0gT21pdDxQbGF0dGVyRml0LCBcInBsYXR0ZXJGaXRJZFwiPiAmIHtcbiAgICBwbGF0dGVyRml0SWQ/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBwbGF0dGVyRml0U2NoZW1hID0gbmV3IGR5bmFtb29zZS5TY2hlbWEoXG4gICAge1xuICAgICAgICBwbGF0dGVyRml0SWQ6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIGhhc2hLZXk6IHRydWUsXG4gICAgICAgICAgICByZXF1aXJlZDogdHJ1ZSxcbiAgICAgICAgICAgIGRlZmF1bHQ6ICgpID0+IHJhbmRvbVVVSUQoKVxuICAgICAgICB9LFxuICAgICAgICBvY2Nhc2lvbk5hbWU6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlXG4gICAgICAgIH0sXG4gICAgICAgIG9jY2FzaW9uVHlwZToge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICAgICAgICBpbmRleDoge1xuICAgICAgICAgICAgICAgIG5hbWU6IFwib2NjYXNpb25UeXBlSW5kZXhcIixcbiAgICAgICAgICAgICAgICB0eXBlOiBcImdsb2JhbFwiXG4gICAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIG9jY2FzaW9uU3ViVHlwZTogU3RyaW5nLFxuICAgICAgICBtaW5QYXg6IHtcbiAgICAgICAgICAgIHR5cGU6IE51bWJlcixcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlXG4gICAgICAgIH0sXG4gICAgICAgIG1heFBheDoge1xuICAgICAgICAgICAgdHlwZTogTnVtYmVyLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgYnVkZ2V0VGllcjoge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgcmFuazoge1xuICAgICAgICAgICAgdHlwZTogTnVtYmVyLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgcmFua1RhZzogU3RyaW5nLFxuICAgICAgICBwbGF0dGVySWQ6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICAgICAgaW5kZXg6IHtcbiAgICAgICAgICAgICAgICBuYW1lOiBcInBsYXR0ZXJJZEluZGV4XCIsXG4gICAgICAgICAgICAgICAgdHlwZTogXCJnbG9iYWxcIlxuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBwbGF0dGVyTmFtZToge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgYnVja2V0UGF4RGVzY3JpcHRpb246IFN0cmluZyxcbiAgICAgICAgb2NjYXNpb25EZXNjcmlwdGlvbjogU3RyaW5nLFxuICAgICAgICBvdGhlcnNEZXNjcmlwdGlvbjogU3RyaW5nLFxuICAgICAgICBzdGF0dXM6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICAgICAgaW5kZXg6IHtcbiAgICAgICAgICAgICAgICBuYW1lOiBcInN0YXR1c0luZGV4XCIsXG4gICAgICAgICAgICAgICAgdHlwZTogXCJnbG9iYWxcIlxuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICAuLi5CQVNFX0RZTkFNT09TRV9BVURJVF9TQ0hFTUFcbiAgICB9LFxuICAgIHtcbiAgICAgICAgc2F2ZVVua25vd246IGZhbHNlXG4gICAgfVxuKTtcblxuZXhwb3J0IGNvbnN0IFBsYXR0ZXJGaXRNb2RlbCA9IGR5bmFtb29zZS5tb2RlbChcbiAgICBQTEFUVEVSX0ZJVF9UQUJMRV9OQU1FLFxuICAgIHBsYXR0ZXJGaXRTY2hlbWEsXG4gICAge1xuICAgICAgICBjcmVhdGU6IGZhbHNlLFxuICAgICAgICB3YWl0Rm9yQWN0aXZlOiBmYWxzZVxuICAgIH1cbik7XG4iXX0=
75
+ exports.PlatterFitModel = dynamoose_1.default.model(exports.PLATTER_FIT_TABLE_NAME, platterFitSchema, { create: false, waitForActive: false });
76
+ /**
77
+ * Converts a plain platter-fit payload into a Dynamoose model instance.
78
+ * Use this before persistence when you want model-level normalization.
79
+ */
80
+ const convertToPlatterFitModel = (platterFit) => {
81
+ return new exports.PlatterFitModel(platterFit);
82
+ };
83
+ exports.convertToPlatterFitModel = convertToPlatterFitModel;
84
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdHRlci1maXQtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VzdG9tZXItdXNlci9wbGF0dGVyLWZpdC1tb2R1bGUvcGxhdHRlci1maXQtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsMERBQWtDO0FBQ2xDLG1DQUFvQztBQUNwQyxxRUFBNkY7QUFFaEYsUUFBQSxzQkFBc0IsR0FBRyxpQkFBaUIsQ0FBQztBQXdCeEQsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLG1CQUFTLENBQUMsTUFBTSxDQUN6QztJQUNJLFlBQVksRUFBRTtRQUNWLElBQUksRUFBRSxNQUFNO1FBQ1osT0FBTyxFQUFFLElBQUk7UUFDYixRQUFRLEVBQUUsSUFBSTtRQUNkLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFBLG1CQUFVLEdBQUU7S0FDOUI7SUFDRCxZQUFZLEVBQUU7UUFDVixJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0QsWUFBWSxFQUFFO1FBQ1YsSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRTtZQUNILElBQUksRUFBRSxtQkFBbUI7WUFDekIsSUFBSSxFQUFFLFFBQVE7U0FDakI7S0FDSjtJQUNELGVBQWUsRUFBRSxNQUFNO0lBQ3ZCLE1BQU0sRUFBRTtRQUNKLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7S0FDakI7SUFDRCxNQUFNLEVBQUU7UUFDSixJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0QsVUFBVSxFQUFFO1FBQ1IsSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtLQUNqQjtJQUNELElBQUksRUFBRTtRQUNGLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7S0FDakI7SUFDRCxPQUFPLEVBQUUsTUFBTTtJQUNmLFNBQVMsRUFBRTtRQUNQLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7UUFDZCxLQUFLLEVBQUU7WUFDSCxJQUFJLEVBQUUsZ0JBQWdCO1lBQ3RCLElBQUksRUFBRSxRQUFRO1NBQ2pCO0tBQ0o7SUFDRCxXQUFXLEVBQUU7UUFDVCxJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0Qsb0JBQW9CLEVBQUUsTUFBTTtJQUM1QixtQkFBbUIsRUFBRSxNQUFNO0lBQzNCLGlCQUFpQixFQUFFLE1BQU07SUFDekIsTUFBTSxFQUFFO1FBQ0osSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRTtZQUNILElBQUksRUFBRSxhQUFhO1lBQ25CLElBQUksRUFBRSxRQUFRO1NBQ2pCO0tBQ0o7SUFDRCxHQUFHLGtEQUEyQjtDQUNqQyxFQUNEO0lBQ0ksV0FBVyxFQUFFLEtBQUs7Q0FDckIsQ0FDSixDQUFDO0FBRVcsUUFBQSxlQUFlLEdBQUcsbUJBQVMsQ0FBQyxLQUFLLENBQzFDLDhCQUFzQixFQUN0QixnQkFBZ0IsRUFDaEIsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSxLQUFLLEVBQUUsQ0FDMUMsQ0FBQztBQUVGOzs7R0FHRztBQUNJLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxVQUE4QyxFQUFFLEVBQUU7SUFDdkYsT0FBTyxJQUFJLHVCQUFlLENBQUMsVUFBVSxDQUFDLENBQUM7QUFDM0MsQ0FBQyxDQUFDO0FBRlcsUUFBQSx3QkFBd0IsNEJBRW5DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGR5bmFtb29zZSBmcm9tIFwiZHluYW1vb3NlXCI7XG5pbXBvcnQgeyByYW5kb21VVUlEIH0gZnJvbSBcImNyeXB0b1wiO1xuaW1wb3J0IHsgQkFTRV9EWU5BTU9PU0VfQVVESVRfU0NIRU1BLCBCYXNlRHluYW1vb3NlTW9kZWwgfSBmcm9tIFwiLi4vLi4vYmFzZS1keW5hbW9vc2UtbW9kZWxcIjtcblxuZXhwb3J0IGNvbnN0IFBMQVRURVJfRklUX1RBQkxFX05BTUUgPSBcIlBsYXR0ZXJGaXRUYWJsZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYXR0ZXJGaXQgZXh0ZW5kcyBCYXNlRHluYW1vb3NlTW9kZWwge1xuICAgIHBsYXR0ZXJGaXRJZDogc3RyaW5nO1xuICAgIG9jY2FzaW9uTmFtZTogc3RyaW5nO1xuICAgIG9jY2FzaW9uVHlwZTogc3RyaW5nO1xuICAgIG9jY2FzaW9uU3ViVHlwZT86IHN0cmluZztcbiAgICBtaW5QYXg6IG51bWJlcjtcbiAgICBtYXhQYXg6IG51bWJlcjtcbiAgICBidWRnZXRUaWVyOiBzdHJpbmc7XG4gICAgcmFuazogbnVtYmVyO1xuICAgIHJhbmtUYWc/OiBzdHJpbmc7XG4gICAgcGxhdHRlcklkOiBzdHJpbmc7XG4gICAgcGxhdHRlck5hbWU6IHN0cmluZztcbiAgICBidWNrZXRQYXhEZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBvY2Nhc2lvbkRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAgIG90aGVyc0Rlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAgIHN0YXR1czogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBDcmVhdGVQbGF0dGVyRml0SW5wdXQgPSBPbWl0PFBsYXR0ZXJGaXQsIFwicGxhdHRlckZpdElkXCI+ICYge1xuICAgIHBsYXR0ZXJGaXRJZD86IHN0cmluZztcbn07XG5cbmNvbnN0IHBsYXR0ZXJGaXRTY2hlbWEgPSBuZXcgZHluYW1vb3NlLlNjaGVtYShcbiAgICB7XG4gICAgICAgIHBsYXR0ZXJGaXRJZDoge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgaGFzaEtleTogdHJ1ZSxcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICAgICAgZGVmYXVsdDogKCkgPT4gcmFuZG9tVVVJRCgpXG4gICAgICAgIH0sXG4gICAgICAgIG9jY2FzaW9uTmFtZToge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgb2NjYXNpb25UeXBlOiB7XG4gICAgICAgICAgICB0eXBlOiBTdHJpbmcsXG4gICAgICAgICAgICByZXF1aXJlZDogdHJ1ZSxcbiAgICAgICAgICAgIGluZGV4OiB7XG4gICAgICAgICAgICAgICAgbmFtZTogXCJvY2Nhc2lvblR5cGVJbmRleFwiLFxuICAgICAgICAgICAgICAgIHR5cGU6IFwiZ2xvYmFsXCJcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgb2NjYXNpb25TdWJUeXBlOiBTdHJpbmcsXG4gICAgICAgIG1pblBheDoge1xuICAgICAgICAgICAgdHlwZTogTnVtYmVyLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgbWF4UGF4OiB7XG4gICAgICAgICAgICB0eXBlOiBOdW1iZXIsXG4gICAgICAgICAgICByZXF1aXJlZDogdHJ1ZVxuICAgICAgICB9LFxuICAgICAgICBidWRnZXRUaWVyOiB7XG4gICAgICAgICAgICB0eXBlOiBTdHJpbmcsXG4gICAgICAgICAgICByZXF1aXJlZDogdHJ1ZVxuICAgICAgICB9LFxuICAgICAgICByYW5rOiB7XG4gICAgICAgICAgICB0eXBlOiBOdW1iZXIsXG4gICAgICAgICAgICByZXF1aXJlZDogdHJ1ZVxuICAgICAgICB9LFxuICAgICAgICByYW5rVGFnOiBTdHJpbmcsXG4gICAgICAgIHBsYXR0ZXJJZDoge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICAgICAgICBpbmRleDoge1xuICAgICAgICAgICAgICAgIG5hbWU6IFwicGxhdHRlcklkSW5kZXhcIixcbiAgICAgICAgICAgICAgICB0eXBlOiBcImdsb2JhbFwiXG4gICAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIHBsYXR0ZXJOYW1lOiB7XG4gICAgICAgICAgICB0eXBlOiBTdHJpbmcsXG4gICAgICAgICAgICByZXF1aXJlZDogdHJ1ZVxuICAgICAgICB9LFxuICAgICAgICBidWNrZXRQYXhEZXNjcmlwdGlvbjogU3RyaW5nLFxuICAgICAgICBvY2Nhc2lvbkRlc2NyaXB0aW9uOiBTdHJpbmcsXG4gICAgICAgIG90aGVyc0Rlc2NyaXB0aW9uOiBTdHJpbmcsXG4gICAgICAgIHN0YXR1czoge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICAgICAgICBpbmRleDoge1xuICAgICAgICAgICAgICAgIG5hbWU6IFwic3RhdHVzSW5kZXhcIixcbiAgICAgICAgICAgICAgICB0eXBlOiBcImdsb2JhbFwiXG4gICAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIC4uLkJBU0VfRFlOQU1PT1NFX0FVRElUX1NDSEVNQVxuICAgIH0sXG4gICAge1xuICAgICAgICBzYXZlVW5rbm93bjogZmFsc2VcbiAgICB9XG4pO1xuXG5leHBvcnQgY29uc3QgUGxhdHRlckZpdE1vZGVsID0gZHluYW1vb3NlLm1vZGVsPFBsYXR0ZXJGaXQ+KFxuICAgIFBMQVRURVJfRklUX1RBQkxFX05BTUUsXG4gICAgcGxhdHRlckZpdFNjaGVtYSxcbiAgICB7IGNyZWF0ZTogZmFsc2UsIHdhaXRGb3JBY3RpdmU6IGZhbHNlIH1cbik7XG5cbi8qKlxuICogQ29udmVydHMgYSBwbGFpbiBwbGF0dGVyLWZpdCBwYXlsb2FkIGludG8gYSBEeW5hbW9vc2UgbW9kZWwgaW5zdGFuY2UuXG4gKiBVc2UgdGhpcyBiZWZvcmUgcGVyc2lzdGVuY2Ugd2hlbiB5b3Ugd2FudCBtb2RlbC1sZXZlbCBub3JtYWxpemF0aW9uLlxuICovXG5leHBvcnQgY29uc3QgY29udmVydFRvUGxhdHRlckZpdE1vZGVsID0gKHBsYXR0ZXJGaXQ6IENyZWF0ZVBsYXR0ZXJGaXRJbnB1dCB8IFBsYXR0ZXJGaXQpID0+IHtcbiAgICByZXR1cm4gbmV3IFBsYXR0ZXJGaXRNb2RlbChwbGF0dGVyRml0KTtcbn07XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cmp-aws-database",
3
- "version": "1.7.1-dev.27",
3
+ "version": "1.7.1-dev.29",
4
4
  "bin": {
5
5
  "craft-my-plate-database": "bin/craft-my-plate-database.js"
6
6
  },