cmp-aws-database 1.1.106 → 1.1.107-dev.1

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/README.md CHANGED
@@ -1,14 +1,232 @@
1
- # Welcome to your CDK TypeScript project
1
+ # Craft My Plate Database Package
2
2
 
3
- This is a blank project for CDK development with TypeScript.
3
+ A comprehensive, environment-aware database package for the Craft My Plate application ecosystem. This package provides DynamoDB-based data access with automatic environment configuration.
4
4
 
5
- The `cdk.json` file tells the CDK Toolkit how to execute your app.
5
+ ## 🚀 Features
6
6
 
7
- ## Useful commands
7
+ - **Environment-Aware Configuration**: Automatically adapts to development, staging, production, and test environments
8
+ - **Dynamic Table Naming**: Environment-specific table prefixes (dev-, staging-, test-)
9
+ - **Feature Flags**: Environment-specific feature toggles (parallel processing, caching, etc.)
10
+ - **TypeScript Support**: Full TypeScript definitions and type safety
11
+ - **AWS CDK Integration**: Infrastructure as Code for database tables
12
+ - **Comprehensive DAO Layer**: Generic data access objects with environment-specific optimizations
8
13
 
9
- * `npm run build` compile typescript to js
10
- * `npm run watch` watch for changes and compile
11
- * `npm run test` perform the jest unit tests
12
- * `npx cdk deploy` deploy this stack to your default AWS account/region
13
- * `npx cdk diff` compare deployed stack with current state
14
- * `npx cdk synth` emits the synthesized CloudFormation template
14
+ ## 📦 Installation
15
+
16
+ ```bash
17
+ npm install cmp-aws-database
18
+ ```
19
+
20
+ ## 🎯 Quick Start
21
+
22
+ ### Basic Usage
23
+
24
+ ```typescript
25
+ import {
26
+ envManager,
27
+ TABLE_NAMES,
28
+ UserModel,
29
+ userDAO
30
+ } from 'cmp-aws-database';
31
+
32
+ // Check current environment
33
+ console.log('Environment:', envManager.getEnvironment());
34
+
35
+ // Use environment-aware table names
36
+ const userTableName = TABLE_NAMES.USER;
37
+
38
+ // Create and save a user
39
+ const user = new UserModel();
40
+ user.userId = 'user123';
41
+ user.email = 'test@example.com';
42
+
43
+ const savedUser = await userDAO.save(user, { userSub: 'auth-user-123' });
44
+ ```
45
+
46
+ ### Environment Configuration
47
+
48
+ The package automatically detects the environment based on `NODE_ENV` or `ENVIRONMENT` variables:
49
+
50
+ ```bash
51
+ # Development
52
+ export NODE_ENV=development
53
+
54
+ # Staging
55
+ export NODE_ENV=staging
56
+
57
+ # Production
58
+ export NODE_ENV=production
59
+
60
+ # Test
61
+ export NODE_ENV=test
62
+ ```
63
+
64
+ ## 🌍 Environment-Specific Behavior
65
+
66
+ ### Development Environment
67
+ - **Database**: Local DynamoDB (http://localhost:8000)
68
+ - **Table Prefix**: `dev-`
69
+ - **Features**: Sequential processing, no caching
70
+ - **Logging**: Debug level
71
+
72
+ ### Staging Environment
73
+ - **Database**: AWS DynamoDB
74
+ - **Table Prefix**: `staging-`
75
+ - **Features**: Parallel processing, caching enabled
76
+ - **Logging**: Info level
77
+
78
+ ### Production Environment
79
+ - **Database**: AWS DynamoDB
80
+ - **Table Prefix**: None (empty)
81
+ - **Features**: Parallel processing, caching enabled
82
+ - **Logging**: Warn level
83
+
84
+ ### Test Environment
85
+ - **Database**: Local DynamoDB (http://localhost:8000)
86
+ - **Table Prefix**: `test-`
87
+ - **Features**: Sequential processing, no caching
88
+ - **Logging**: Error level
89
+
90
+ ## 📚 Available Models and DAOs
91
+
92
+ ### Customer User Models
93
+ - `UserModel` / `userDAO`
94
+ - `OrderModel` / `orderDao`
95
+ - `CartModel` / `cartDAO`
96
+ - `WalletModel` / `walletDao`
97
+ - `PaymentModel` / `paymentDao`
98
+ - And many more...
99
+
100
+ ### Internal User Models
101
+ - `InternalUserModel` / `internalUserDao`
102
+ - `ActivityLogsModel` / `activityLogsDao`
103
+ - `QuotationsModel` / `quotationsDao`
104
+
105
+ ## 🔧 Advanced Usage
106
+
107
+ ### Environment-Specific Features
108
+
109
+ ```typescript
110
+ import { envManager } from 'cmp-aws-database';
111
+
112
+ const config = envManager.getConfig();
113
+
114
+ // Check if parallel processing is enabled
115
+ if (config.features.enableParallelProcessing) {
116
+ await userDAO.parallelBatchGet(users);
117
+ } else {
118
+ await userDAO.batchGet(users);
119
+ }
120
+
121
+ // Check if caching is enabled
122
+ if (config.features.enableCaching) {
123
+ // Implement caching logic
124
+ }
125
+ ```
126
+
127
+ ### Custom Table Names
128
+
129
+ ```typescript
130
+ import { TableNameManager } from 'cmp-aws-database';
131
+
132
+ const customTableName = TableNameManager.getTableName('MyCustomTable');
133
+ // Returns: dev-MyCustomTable, staging-MyCustomTable, or MyCustomTable
134
+ ```
135
+
136
+ ### Environment Override (Testing)
137
+
138
+ ```typescript
139
+ import { envManager } from 'cmp-aws-database';
140
+
141
+ // Override environment for testing
142
+ envManager.setEnvironment('test');
143
+ ```
144
+
145
+ ## 🏗️ Infrastructure
146
+
147
+ ### CDK Stack Deployment
148
+
149
+ ```typescript
150
+ import { CustomerAppDbStack, InternalUserDbStack } from 'cmp-aws-database';
151
+
152
+ // Deploy customer app database
153
+ const customerStack = new CustomerAppDbStack(app, 'CustomerAppDbStack');
154
+
155
+ // Deploy internal user database
156
+ const internalStack = new InternalUserDbStack(app, 'InternalUserDbStack');
157
+ ```
158
+
159
+ ### Available Tables
160
+
161
+ The package includes pre-configured tables for:
162
+ - User management
163
+ - Order processing
164
+ - Payment handling
165
+ - Inventory management
166
+ - Analytics and reporting
167
+ - And much more...
168
+
169
+ ## 🔍 Debugging
170
+
171
+ ### Environment Information
172
+
173
+ ```typescript
174
+ import { envManager } from 'cmp-aws-database';
175
+
176
+ console.log('Current environment:', envManager.getEnvironment());
177
+ console.log('Database config:', envManager.getDatabaseConfig());
178
+ console.log('Features enabled:', envManager.getConfig().features);
179
+ ```
180
+
181
+ ### Table Name Resolution
182
+
183
+ ```typescript
184
+ import { TABLE_NAMES, BASE_TABLE_NAMES } from 'cmp-aws-database';
185
+
186
+ console.log('Environment-aware table names:', TABLE_NAMES);
187
+ console.log('Base table names:', BASE_TABLE_NAMES);
188
+ ```
189
+
190
+ ## 📋 Migration Guide
191
+
192
+ ### From Hardcoded Configuration
193
+
194
+ **Before:**
195
+ ```typescript
196
+ const tableName = 'UserTable';
197
+ const client = new DynamoDB({ maxAttempts: 10 });
198
+ ```
199
+
200
+ **After:**
201
+ ```typescript
202
+ import { TABLE_NAMES, DatabaseFactory } from 'cmp-aws-database';
203
+
204
+ const tableName = TABLE_NAMES.USER;
205
+ const client = DatabaseFactory.getDynamoDBClient();
206
+ ```
207
+
208
+ ## 🤝 Contributing
209
+
210
+ 1. Fork the repository
211
+ 2. Create a feature branch
212
+ 3. Make your changes
213
+ 4. Add tests for new functionality
214
+ 5. Submit a pull request
215
+
216
+ ## 📄 License
217
+
218
+ Apache-2.0
219
+
220
+ ## 🆘 Support
221
+
222
+ - **Issues**: [GitHub Issues](https://github.com/Surajpatel24-craftmyplate/craft-my-plate-database/issues)
223
+ - **Documentation**: [Package Documentation](https://github.com/Surajpatel24-craftmyplate/craft-my-plate-database#readme)
224
+
225
+ ## 🔄 Version History
226
+
227
+ - **1.1.107**: Current version with environment-aware configuration
228
+ - **Previous versions**: Legacy hardcoded configuration
229
+
230
+ ---
231
+
232
+ **Note**: This package is designed to work seamlessly across different environments while maintaining the same API. The environment-specific behavior is handled internally, so your application code remains consistent across all environments.
@@ -1,8 +1,9 @@
1
+ import { DynamoDB } from '@aws-sdk/client-dynamodb';
1
2
  import { DataMapper, ParallelScanOptions, ParallelScanWorkerOptions, QueryOptions, ReadConsistency, ScanOptions } from '@nova-odm/mapper';
2
3
  import { ZeroArgumentsConstructor } from '@nova-odm/marshaller';
3
4
  import { ConditionExpression, ConditionExpressionPredicate } from '@nova-odm/expressions';
4
5
  import { BaseModel } from './base-model';
5
- export declare const dynamoDB: any;
6
+ export declare const dynamoDB: DynamoDB;
6
7
  export declare const mapper: DataMapper;
7
8
  export declare class GenericDAO<T extends BaseModel> {
8
9
  batchUpdate(items: T[], batchSize?: number, authContext?: any): Promise<T[]>;
package/dist/base-dao.js CHANGED
@@ -1,12 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.GenericDAO = exports.mapper = exports.dynamoDB = void 0;
4
- const client_dynamodb_1 = require("@aws-sdk/client-dynamodb");
5
- const mapper_1 = require("@nova-odm/mapper");
6
- exports.dynamoDB = new client_dynamodb_1.DynamoDB({
7
- maxAttempts: 10
8
- });
9
- exports.mapper = new mapper_1.DataMapper({ client: exports.dynamoDB });
4
+ const database_factory_1 = require("./config/database-factory");
5
+ const environment_config_1 = require("./config/environment-config");
6
+ // Use environment-aware database instances
7
+ exports.dynamoDB = database_factory_1.DatabaseFactory.getDynamoDBClient();
8
+ exports.mapper = database_factory_1.DatabaseFactory.getDataMapper();
10
9
  class GenericDAO {
11
10
  async batchUpdate(items, batchSize = 100, authContext) {
12
11
  let success = 0, totalToUpdate = items.length;
@@ -132,9 +131,12 @@ class GenericDAO {
132
131
  async delete(item) {
133
132
  return await exports.mapper.delete(item, { returnValues: "ALL_OLD" });
134
133
  }
135
- async get(item, readConsistency = "eventual") {
134
+ async get(item, readConsistency) {
135
+ // Use environment-specific read consistency if not provided
136
+ const config = environment_config_1.envManager.getDatabaseConfig();
137
+ const consistency = readConsistency || config.readConsistency;
136
138
  const res = await exports.mapper.get(item, {
137
- readConsistency: readConsistency
139
+ readConsistency: consistency
138
140
  });
139
141
  return res;
140
142
  }
@@ -159,16 +161,25 @@ class GenericDAO {
159
161
  }
160
162
  return deleteItems;
161
163
  }
162
- async batchGet(items, readConsistency = "eventual") {
164
+ async batchGet(items, readConsistency) {
165
+ // Use environment-specific read consistency if not provided
166
+ const config = environment_config_1.envManager.getDatabaseConfig();
167
+ const consistency = readConsistency || config.readConsistency;
163
168
  let getItems = [];
164
169
  for await (const item of exports.mapper.batchGet(items, {
165
- readConsistency: readConsistency
170
+ readConsistency: consistency
166
171
  })) {
167
172
  getItems.push(item);
168
173
  }
169
174
  return getItems;
170
175
  }
171
176
  async parallelBatchGet(inputItems, batchSize = 1000, maxConcurrentSegments = 20, readConsistency) {
177
+ // Check if parallel processing is enabled for this environment
178
+ const config = environment_config_1.envManager.getConfig();
179
+ if (!config.features.enableParallelProcessing) {
180
+ console.warn('Parallel processing is disabled for this environment. Using sequential processing.');
181
+ return this.batchGet(inputItems, readConsistency);
182
+ }
172
183
  let startTime = Date.now();
173
184
  let items = [];
174
185
  items = items.concat(inputItems);
@@ -242,4 +253,4 @@ class GenericDAO {
242
253
  }
243
254
  }
244
255
  exports.GenericDAO = GenericDAO;
245
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dao.js","sourceRoot":"","sources":["../src/base-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import { DynamoDB } from '@aws-sdk/client-dynamodb';\nimport {\n    DataMapper,\n    ParallelScanOptions,\n    ParallelScanWorkerOptions,\n    QueryOptions,\n    ReadConsistency,\n    ScanOptions\n} from '@nova-odm/mapper';\nimport { ZeroArgumentsConstructor } from '@nova-odm/marshaller';\nimport { ConditionExpression, ConditionExpressionPredicate } from '@nova-odm/expressions';\nimport { BaseModel } from './base-model';\n\n\nexport const dynamoDB = new DynamoDB({\n    maxAttempts: 10\n}) as any\nexport const mapper = new DataMapper({ client: dynamoDB });\n\nexport class GenericDAO<T extends BaseModel> {\n    async batchUpdate(items: T[], batchSize = 100, authContext?: any): Promise<T[]> {\n        let success = 0, totalToUpdate = items.length\n        let updateItems: T[] = []\n        while (items.length > 0) {\n            let promises = []\n            let batch = items.splice(0, batchSize)\n            promises = batch.map(item => this.update(item, authContext))\n            let results = await Promise.allSettled(promises)\n            results.forEach(result => {\n                if (result.status == \"fulfilled\") {\n                    success += 1\n                    updateItems.push(result.value)\n                }\n            })\n            console.log(`${success}/${totalToUpdate}`)\n        }\n        return updateItems\n    }\n\n    async parallelBatchPut(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20, authContext?: any): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        items = items.map(item => {\n            item.created_time = new Date()\n            item.created_user = authContext.userSub\n            return item\n        })\n        let maxSegments: T[][][] = []\n        let putItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchPut(batch, authContext.userSub))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                putItems = putItems.concat(res)\n            })\n            console.log(`time for segment put ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel put ${Date.now() - startTime}`)\n        return putItems\n    }\n\n    async parallelBatchDelete(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        let maxSegments: T[][][] = []\n        let putItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchDelete(batch))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                putItems = putItems.concat(res)\n            })\n            console.log(`time for segment delete ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel delete ${Date.now() - startTime}`)\n        return putItems\n    }\n\n    /**\n     * This function has to be used only in the scripts.\n     * \n     * @param valueConstructor the model class\n     */\n    async parallelScan(valueConstructor: ZeroArgumentsConstructor<T>, options?: ParallelScanOptions): Promise<T[]> {\n        let items: T[] = []\n        for await (const item of mapper.parallelScan(valueConstructor, 4, options)) {\n            items.push(item)\n            if (items.length % 100000 == 0) {\n                console.log(\"read 100K\")\n            }\n        }\n        return items\n    }\n\n    async scan(valueConstructor: ZeroArgumentsConstructor<T>, options?: ScanOptions | ParallelScanWorkerOptions): Promise<T[]> {\n        let items: T[] = []\n        for await (const item of mapper.scan(valueConstructor, options)) {\n            items.push(item)\n        }\n        return items\n    }\n\n    async save(item: T, authContext?: any): Promise<T> {\n        item.created_time = new Date()\n        item.created_user = authContext.userSub\n        const res = await mapper.put(item)\n        return res\n    }\n\n    async update(item: T, authContext?: any): Promise<T> {\n        item.updated_time = new Date()\n        item.updated_user = authContext.userSub\n        const res = await mapper.update(item, {\n            onMissing: \"skip\"\n        })\n        return res\n    }\n\n    async delete(item: T): Promise<T | undefined> {\n        return await mapper.delete(item, { returnValues: \"ALL_OLD\" })\n    }\n\n    async get(item: T, readConsistency: ReadConsistency = \"eventual\"): Promise<T> {\n        const res = await mapper.get(item, {\n            readConsistency: readConsistency\n        })\n        return res\n    }\n\n    async batchPut(items: T[], authContext?: any): Promise<T[]> {\n\n        let finalItems: T[] = []\n        items = items.map(item => {\n            item.created_time = new Date()\n            item.created_user = authContext.userSub\n            return item\n        })\n        // console.log( \"item:\", items )\n        for await (const item of mapper.batchPut(items)) {\n            console.log(item)\n            finalItems.push(item)\n        }\n        return finalItems\n    }\n\n    async batchDelete(items: T[]): Promise<T[]> {\n        let deleteItems: T[] = []\n        for await (const item of mapper.batchDelete(items)) {\n            deleteItems.push(item)\n        }\n        return deleteItems\n    }\n\n    async batchGet(items: T[], readConsistency: ReadConsistency = \"eventual\"): Promise<T[]> {\n        let getItems: T[] = []\n        for await (const item of mapper.batchGet(items, {\n            readConsistency: readConsistency\n        })) {\n            getItems.push(item)\n        }\n        return getItems\n    }\n\n    async parallelBatchGet(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20, readConsistency?: ReadConsistency): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        let maxSegments: T[][][] = []\n        let resultItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchGet(batch, readConsistency))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                resultItems = resultItems.concat(res)\n            })\n            console.log(`time for segment get ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel get ${Date.now() - startTime}`)\n        return resultItems\n    }\n    async parallelQuery(\n        valueConstructor: ZeroArgumentsConstructor<T>,\n        keyConditions: Array<ConditionExpression | { [propertyName: string]: ConditionExpressionPredicate | any }>,\n        maxConcurrentCalls: number = 20,\n        options?: QueryOptions,\n\n    ): Promise<T[]> {\n        const startTime = Date.now()\n        const results: T[] = []\n        while (keyConditions.length > 0) {\n            const segmentConditions = keyConditions.splice(0, maxConcurrentCalls)\n            const queryPromises = segmentConditions.map((keyCondition) => {\n                return this.customQuery(valueConstructor, keyCondition, options)\n            }\n\n            )\n            const queryResults = await Promise.all(queryPromises)\n\n            for (const queryResult of queryResults) {\n                results.push(...queryResult)\n            }\n        }\n        console.log(`total time for complete parallel query ${Date.now() - startTime}`)\n        return results\n    }\n    private async customQuery(\n        valueConstructor: ZeroArgumentsConstructor<T>,\n        keyConditions: ConditionExpression | { [propertyName: string]: ConditionExpressionPredicate | any },\n        options?: QueryOptions\n    ): Promise<T[]> {\n        const startTime = Date.now()\n        const items: T[] = []\n\n        for await (const item of mapper.query(valueConstructor, keyConditions, options)) {\n            items.push(item)\n        }\n        console.log(`total time for complete query ${Date.now() - startTime}`)\n\n        return items\n    }\n    decode(continuationToken: string | undefined) {\n        if (continuationToken) {\n            try {\n                let lastEvaluatedKey = JSON.parse(Buffer.from(continuationToken, 'base64').toString('utf8'));\n                console.log(\"Incoming Last Evaluated Key \" + lastEvaluatedKey);\n                return lastEvaluatedKey;\n            } catch (error) {\n                throw new Error('Invalid continuationToken');\n            }\n        }\n        return undefined\n    }\n\n    async encode(lastEvaluatedKey: any): Promise<string> {\n        return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString('base64')\n    }\n}"]}
256
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dao.js","sourceRoot":"","sources":["../src/base-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import { DynamoDB } from '@aws-sdk/client-dynamodb';\nimport {\n    DataMapper,\n    ParallelScanOptions,\n    ParallelScanWorkerOptions,\n    QueryOptions,\n    ReadConsistency,\n    ScanOptions\n} from '@nova-odm/mapper';\nimport { ZeroArgumentsConstructor } from '@nova-odm/marshaller';\nimport { ConditionExpression, ConditionExpressionPredicate } from '@nova-odm/expressions';\nimport { BaseModel } from './base-model';\nimport { DatabaseFactory } from './config/database-factory';\nimport { envManager } from './config/environment-config';\n\n// Use environment-aware database instances\nexport const dynamoDB = DatabaseFactory.getDynamoDBClient();\nexport const mapper = DatabaseFactory.getDataMapper();\n\nexport class GenericDAO<T extends BaseModel> {\n    async batchUpdate(items: T[], batchSize = 100, authContext?: any): Promise<T[]> {\n        let success = 0, totalToUpdate = items.length\n        let updateItems: T[] = []\n        while (items.length > 0) {\n            let promises = []\n            let batch = items.splice(0, batchSize)\n            promises = batch.map(item => this.update(item, authContext))\n            let results = await Promise.allSettled(promises)\n            results.forEach(result => {\n                if (result.status == \"fulfilled\") {\n                    success += 1\n                    updateItems.push(result.value)\n                }\n            })\n            console.log(`${success}/${totalToUpdate}`)\n        }\n        return updateItems\n    }\n\n    async parallelBatchPut(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20, authContext?: any): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        items = items.map(item => {\n            item.created_time = new Date()\n            item.created_user = authContext.userSub\n            return item\n        })\n        let maxSegments: T[][][] = []\n        let putItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchPut(batch, authContext.userSub))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                putItems = putItems.concat(res)\n            })\n            console.log(`time for segment put ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel put ${Date.now() - startTime}`)\n        return putItems\n    }\n\n    async parallelBatchDelete(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20): Promise<T[]> {\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        let maxSegments: T[][][] = []\n        let putItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchDelete(batch))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                putItems = putItems.concat(res)\n            })\n            console.log(`time for segment delete ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel delete ${Date.now() - startTime}`)\n        return putItems\n    }\n\n    /**\n     * This function has to be used only in the scripts.\n     * \n     * @param valueConstructor the model class\n     */\n    async parallelScan(valueConstructor: ZeroArgumentsConstructor<T>, options?: ParallelScanOptions): Promise<T[]> {\n        let items: T[] = []\n        for await (const item of mapper.parallelScan(valueConstructor, 4, options)) {\n            items.push(item)\n            if (items.length % 100000 == 0) {\n                console.log(\"read 100K\")\n            }\n        }\n        return items\n    }\n\n    async scan(valueConstructor: ZeroArgumentsConstructor<T>, options?: ScanOptions | ParallelScanWorkerOptions): Promise<T[]> {\n        let items: T[] = []\n        for await (const item of mapper.scan(valueConstructor, options)) {\n            items.push(item)\n        }\n        return items\n    }\n\n    async save(item: T, authContext?: any): Promise<T> {\n        item.created_time = new Date()\n        item.created_user = authContext.userSub\n        const res = await mapper.put(item)\n        return res\n    }\n\n    async update(item: T, authContext?: any): Promise<T> {\n        item.updated_time = new Date()\n        item.updated_user = authContext.userSub\n        const res = await mapper.update(item, {\n            onMissing: \"skip\"\n        })\n        return res\n    }\n\n    async delete(item: T): Promise<T | undefined> {\n        return await mapper.delete(item, { returnValues: \"ALL_OLD\" })\n    }\n\n    async get(item: T, readConsistency?: ReadConsistency): Promise<T> {\n        // Use environment-specific read consistency if not provided\n        const config = envManager.getDatabaseConfig();\n        const consistency = readConsistency || config.readConsistency;\n\n        const res = await mapper.get(item, {\n            readConsistency: consistency\n        })\n        return res\n    }\n\n    async batchPut(items: T[], authContext?: any): Promise<T[]> {\n\n        let finalItems: T[] = []\n        items = items.map(item => {\n            item.created_time = new Date()\n            item.created_user = authContext.userSub\n            return item\n        })\n        // console.log( \"item:\", items )\n        for await (const item of mapper.batchPut(items)) {\n            console.log(item)\n            finalItems.push(item)\n        }\n        return finalItems\n    }\n\n    async batchDelete(items: T[]): Promise<T[]> {\n        let deleteItems: T[] = []\n        for await (const item of mapper.batchDelete(items)) {\n            deleteItems.push(item)\n        }\n        return deleteItems\n    }\n\n    async batchGet(items: T[], readConsistency?: ReadConsistency): Promise<T[]> {\n        // Use environment-specific read consistency if not provided\n        const config = envManager.getDatabaseConfig();\n        const consistency = readConsistency || config.readConsistency;\n\n        let getItems: T[] = []\n        for await (const item of mapper.batchGet(items, {\n            readConsistency: consistency\n        })) {\n            getItems.push(item)\n        }\n        return getItems\n    }\n\n    async parallelBatchGet(inputItems: T[], batchSize: number = 1000, maxConcurrentSegments: number = 20, readConsistency?: ReadConsistency): Promise<T[]> {\n        // Check if parallel processing is enabled for this environment\n        const config = envManager.getConfig();\n        if (!config.features.enableParallelProcessing) {\n            console.warn('Parallel processing is disabled for this environment. Using sequential processing.');\n            return this.batchGet(inputItems, readConsistency);\n        }\n\n        let startTime = Date.now()\n        let items: T[] = []\n        items = items.concat(inputItems)\n        let maxSegments: T[][][] = []\n        let resultItems: T[] = []\n        while (items.length > 0) {\n            let batch = items.splice(0, batchSize * maxConcurrentSegments)\n            let segment: T[][] = []\n            while (batch.length > 0) {\n                segment.push(batch.splice(0, batchSize))\n            }\n            maxSegments.push(segment)\n        }\n        for (const segment of maxSegments) {\n            let startTime = Date.now()\n            let promises: Promise<T[]>[] = []\n            console.log(`batch length = ${segment.length}`)\n            for (const batch of segment) {\n                promises.push(this.batchGet(batch, readConsistency))\n            }\n            let result = await Promise.all(promises)\n            console.log(\"segment complete\")\n            result.forEach((res) => {\n                resultItems = resultItems.concat(res)\n            })\n            console.log(`time for segment get ${Date.now() - startTime}`)\n        }\n        console.log(`total time for complete parallel get ${Date.now() - startTime}`)\n        return resultItems\n    }\n    async parallelQuery(\n        valueConstructor: ZeroArgumentsConstructor<T>,\n        keyConditions: Array<ConditionExpression | { [propertyName: string]: ConditionExpressionPredicate | any }>,\n        maxConcurrentCalls: number = 20,\n        options?: QueryOptions,\n\n    ): Promise<T[]> {\n        const startTime = Date.now()\n        const results: T[] = []\n        while (keyConditions.length > 0) {\n            const segmentConditions = keyConditions.splice(0, maxConcurrentCalls)\n            const queryPromises = segmentConditions.map((keyCondition) => {\n                return this.customQuery(valueConstructor, keyCondition, options)\n            }\n\n            )\n            const queryResults = await Promise.all(queryPromises)\n\n            for (const queryResult of queryResults) {\n                results.push(...queryResult)\n            }\n        }\n        console.log(`total time for complete parallel query ${Date.now() - startTime}`)\n        return results\n    }\n    private async customQuery(\n        valueConstructor: ZeroArgumentsConstructor<T>,\n        keyConditions: ConditionExpression | { [propertyName: string]: ConditionExpressionPredicate | any },\n        options?: QueryOptions\n    ): Promise<T[]> {\n        const startTime = Date.now()\n        const items: T[] = []\n\n        for await (const item of mapper.query(valueConstructor, keyConditions, options)) {\n            items.push(item)\n        }\n        console.log(`total time for complete query ${Date.now() - startTime}`)\n\n        return items\n    }\n    decode(continuationToken: string | undefined) {\n        if (continuationToken) {\n            try {\n                let lastEvaluatedKey = JSON.parse(Buffer.from(continuationToken, 'base64').toString('utf8'));\n                console.log(\"Incoming Last Evaluated Key \" + lastEvaluatedKey);\n                return lastEvaluatedKey;\n            } catch (error) {\n                throw new Error('Invalid continuationToken');\n            }\n        }\n        return undefined\n    }\n\n    async encode(lastEvaluatedKey: any): Promise<string> {\n        return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString('base64')\n    }\n}"]}
@@ -0,0 +1,12 @@
1
+ import { DynamoDB } from '@aws-sdk/client-dynamodb';
2
+ import { DataMapper } from '@nova-odm/mapper';
3
+ export declare class DatabaseFactory {
4
+ private static dynamoDBInstance;
5
+ private static mapperInstance;
6
+ static getDynamoDBClient(): DynamoDB;
7
+ static getDataMapper(): DataMapper;
8
+ static getTableName(baseTableName: string): string;
9
+ static resetInstances(): void;
10
+ }
11
+ export declare const dynamoDB: DynamoDB;
12
+ export declare const mapper: DataMapper;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.mapper = exports.dynamoDB = exports.DatabaseFactory = void 0;
4
+ const client_dynamodb_1 = require("@aws-sdk/client-dynamodb");
5
+ const mapper_1 = require("@nova-odm/mapper");
6
+ const environment_config_1 = require("./environment-config");
7
+ class DatabaseFactory {
8
+ static getDynamoDBClient() {
9
+ if (!DatabaseFactory.dynamoDBInstance) {
10
+ const config = environment_config_1.envManager.getDatabaseConfig();
11
+ const dynamoConfig = {
12
+ region: config.region,
13
+ maxAttempts: config.maxAttempts
14
+ };
15
+ // Add endpoint for local development
16
+ if (config.endpoint) {
17
+ dynamoConfig.endpoint = config.endpoint;
18
+ }
19
+ DatabaseFactory.dynamoDBInstance = new client_dynamodb_1.DynamoDB(dynamoConfig);
20
+ }
21
+ return DatabaseFactory.dynamoDBInstance;
22
+ }
23
+ static getDataMapper() {
24
+ if (!DatabaseFactory.mapperInstance) {
25
+ const client = DatabaseFactory.getDynamoDBClient();
26
+ DatabaseFactory.mapperInstance = new mapper_1.DataMapper({ client });
27
+ }
28
+ return DatabaseFactory.mapperInstance;
29
+ }
30
+ static getTableName(baseTableName) {
31
+ const config = environment_config_1.envManager.getDatabaseConfig();
32
+ return `${config.tablePrefix}${baseTableName}`;
33
+ }
34
+ static resetInstances() {
35
+ DatabaseFactory.dynamoDBInstance = undefined;
36
+ DatabaseFactory.mapperInstance = undefined;
37
+ }
38
+ }
39
+ exports.DatabaseFactory = DatabaseFactory;
40
+ // Export singleton instances for backward compatibility
41
+ exports.dynamoDB = DatabaseFactory.getDynamoDBClient();
42
+ exports.mapper = DatabaseFactory.getDataMapper();
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWJhc2UtZmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcvZGF0YWJhc2UtZmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw4REFBb0Q7QUFDcEQsNkNBQThDO0FBQzlDLDZEQUFrRTtBQUVsRSxNQUFhLGVBQWU7SUFJakIsTUFBTSxDQUFDLGlCQUFpQjtRQUMzQixJQUFJLENBQUMsZUFBZSxDQUFDLGdCQUFnQixFQUFFLENBQUM7WUFDcEMsTUFBTSxNQUFNLEdBQUcsK0JBQVUsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBRTlDLE1BQU0sWUFBWSxHQUFRO2dCQUN0QixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU07Z0JBQ3JCLFdBQVcsRUFBRSxNQUFNLENBQUMsV0FBVzthQUNsQyxDQUFDO1lBRUYscUNBQXFDO1lBQ3JDLElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUNsQixZQUFZLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUM7WUFDNUMsQ0FBQztZQUVELGVBQWUsQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLDBCQUFRLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDbEUsQ0FBQztRQUVELE9BQU8sZUFBZSxDQUFDLGdCQUFnQixDQUFDO0lBQzVDLENBQUM7SUFFTSxNQUFNLENBQUMsYUFBYTtRQUN2QixJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ2xDLE1BQU0sTUFBTSxHQUFHLGVBQWUsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQ25ELGVBQWUsQ0FBQyxjQUFjLEdBQUcsSUFBSSxtQkFBVSxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUNoRSxDQUFDO1FBRUQsT0FBTyxlQUFlLENBQUMsY0FBYyxDQUFDO0lBQzFDLENBQUM7SUFFTSxNQUFNLENBQUMsWUFBWSxDQUFDLGFBQXFCO1FBQzVDLE1BQU0sTUFBTSxHQUFHLCtCQUFVLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUM5QyxPQUFPLEdBQUcsTUFBTSxDQUFDLFdBQVcsR0FBRyxhQUFhLEVBQUUsQ0FBQztJQUNuRCxDQUFDO0lBRU0sTUFBTSxDQUFDLGNBQWM7UUFDeEIsZUFBZSxDQUFDLGdCQUFnQixHQUFHLFNBQWdCLENBQUM7UUFDcEQsZUFBZSxDQUFDLGNBQWMsR0FBRyxTQUFnQixDQUFDO0lBQ3RELENBQUM7Q0FDSjtBQTFDRCwwQ0EwQ0M7QUFFRCx3REFBd0Q7QUFDM0MsUUFBQSxRQUFRLEdBQUcsZUFBZSxDQUFDLGlCQUFpQixFQUFFLENBQUM7QUFDL0MsUUFBQSxNQUFNLEdBQUcsZUFBZSxDQUFDLGFBQWEsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRHluYW1vREIgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtZHluYW1vZGInO1xuaW1wb3J0IHsgRGF0YU1hcHBlciB9IGZyb20gJ0Bub3ZhLW9kbS9tYXBwZXInO1xuaW1wb3J0IHsgZW52TWFuYWdlciwgRGF0YWJhc2VDb25maWcgfSBmcm9tICcuL2Vudmlyb25tZW50LWNvbmZpZyc7XG5cbmV4cG9ydCBjbGFzcyBEYXRhYmFzZUZhY3Rvcnkge1xuICAgIHByaXZhdGUgc3RhdGljIGR5bmFtb0RCSW5zdGFuY2U6IER5bmFtb0RCO1xuICAgIHByaXZhdGUgc3RhdGljIG1hcHBlckluc3RhbmNlOiBEYXRhTWFwcGVyO1xuXG4gICAgcHVibGljIHN0YXRpYyBnZXREeW5hbW9EQkNsaWVudCgpOiBEeW5hbW9EQiB7XG4gICAgICAgIGlmICghRGF0YWJhc2VGYWN0b3J5LmR5bmFtb0RCSW5zdGFuY2UpIHtcbiAgICAgICAgICAgIGNvbnN0IGNvbmZpZyA9IGVudk1hbmFnZXIuZ2V0RGF0YWJhc2VDb25maWcoKTtcblxuICAgICAgICAgICAgY29uc3QgZHluYW1vQ29uZmlnOiBhbnkgPSB7XG4gICAgICAgICAgICAgICAgcmVnaW9uOiBjb25maWcucmVnaW9uLFxuICAgICAgICAgICAgICAgIG1heEF0dGVtcHRzOiBjb25maWcubWF4QXR0ZW1wdHNcbiAgICAgICAgICAgIH07XG5cbiAgICAgICAgICAgIC8vIEFkZCBlbmRwb2ludCBmb3IgbG9jYWwgZGV2ZWxvcG1lbnRcbiAgICAgICAgICAgIGlmIChjb25maWcuZW5kcG9pbnQpIHtcbiAgICAgICAgICAgICAgICBkeW5hbW9Db25maWcuZW5kcG9pbnQgPSBjb25maWcuZW5kcG9pbnQ7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIERhdGFiYXNlRmFjdG9yeS5keW5hbW9EQkluc3RhbmNlID0gbmV3IER5bmFtb0RCKGR5bmFtb0NvbmZpZyk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gRGF0YWJhc2VGYWN0b3J5LmR5bmFtb0RCSW5zdGFuY2U7XG4gICAgfVxuXG4gICAgcHVibGljIHN0YXRpYyBnZXREYXRhTWFwcGVyKCk6IERhdGFNYXBwZXIge1xuICAgICAgICBpZiAoIURhdGFiYXNlRmFjdG9yeS5tYXBwZXJJbnN0YW5jZSkge1xuICAgICAgICAgICAgY29uc3QgY2xpZW50ID0gRGF0YWJhc2VGYWN0b3J5LmdldER5bmFtb0RCQ2xpZW50KCk7XG4gICAgICAgICAgICBEYXRhYmFzZUZhY3RvcnkubWFwcGVySW5zdGFuY2UgPSBuZXcgRGF0YU1hcHBlcih7IGNsaWVudCB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBEYXRhYmFzZUZhY3RvcnkubWFwcGVySW5zdGFuY2U7XG4gICAgfVxuXG4gICAgcHVibGljIHN0YXRpYyBnZXRUYWJsZU5hbWUoYmFzZVRhYmxlTmFtZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgY29uZmlnID0gZW52TWFuYWdlci5nZXREYXRhYmFzZUNvbmZpZygpO1xuICAgICAgICByZXR1cm4gYCR7Y29uZmlnLnRhYmxlUHJlZml4fSR7YmFzZVRhYmxlTmFtZX1gO1xuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgcmVzZXRJbnN0YW5jZXMoKTogdm9pZCB7XG4gICAgICAgIERhdGFiYXNlRmFjdG9yeS5keW5hbW9EQkluc3RhbmNlID0gdW5kZWZpbmVkIGFzIGFueTtcbiAgICAgICAgRGF0YWJhc2VGYWN0b3J5Lm1hcHBlckluc3RhbmNlID0gdW5kZWZpbmVkIGFzIGFueTtcbiAgICB9XG59XG5cbi8vIEV4cG9ydCBzaW5nbGV0b24gaW5zdGFuY2VzIGZvciBiYWNrd2FyZCBjb21wYXRpYmlsaXR5XG5leHBvcnQgY29uc3QgZHluYW1vREIgPSBEYXRhYmFzZUZhY3RvcnkuZ2V0RHluYW1vREJDbGllbnQoKTtcbmV4cG9ydCBjb25zdCBtYXBwZXIgPSBEYXRhYmFzZUZhY3RvcnkuZ2V0RGF0YU1hcHBlcigpO1xuIl19
@@ -0,0 +1,38 @@
1
+ export type Environment = 'DEV' | 'PRODDEBUG' | 'PROD' | 'test';
2
+ export interface DatabaseConfig {
3
+ region: string;
4
+ endpoint?: string;
5
+ maxAttempts: number;
6
+ tablePrefix: string;
7
+ enableLogging: boolean;
8
+ readConsistency: 'eventual' | 'strong';
9
+ }
10
+ export interface EnvironmentConfig {
11
+ environment: Environment;
12
+ database: DatabaseConfig;
13
+ features: {
14
+ enableParallelProcessing: boolean;
15
+ enableBatchOperations: boolean;
16
+ enableCaching: boolean;
17
+ };
18
+ monitoring: {
19
+ enableMetrics: boolean;
20
+ logLevel: 'debug' | 'info' | 'warn' | 'error';
21
+ };
22
+ }
23
+ export declare class EnvironmentManager {
24
+ private static instance;
25
+ private currentConfig;
26
+ private constructor();
27
+ static getInstance(): EnvironmentManager;
28
+ private loadEnvironmentConfig;
29
+ getConfig(): EnvironmentConfig;
30
+ getDatabaseConfig(): DatabaseConfig;
31
+ getEnvironment(): Environment;
32
+ isDEV(): boolean;
33
+ isPROD(): boolean;
34
+ isPRODDEBUG(): boolean;
35
+ isTest(): boolean;
36
+ setEnvironment(environment: Environment): void;
37
+ }
38
+ export declare const envManager: EnvironmentManager;
@@ -0,0 +1,133 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.envManager = exports.EnvironmentManager = void 0;
4
+ // Environment-specific configurations
5
+ const environmentConfigs = {
6
+ DEV: {
7
+ environment: 'DEV',
8
+ database: {
9
+ region: 'us-east-1',
10
+ endpoint: 'http://localhost:8000', // Local DynamoDB
11
+ maxAttempts: 3,
12
+ tablePrefix: 'dev-',
13
+ enableLogging: true,
14
+ readConsistency: 'eventual'
15
+ },
16
+ features: {
17
+ enableParallelProcessing: false,
18
+ enableBatchOperations: true,
19
+ enableCaching: false
20
+ },
21
+ monitoring: {
22
+ enableMetrics: false,
23
+ logLevel: 'debug'
24
+ }
25
+ },
26
+ PRODDEBUG: {
27
+ environment: 'PRODDEBUG',
28
+ database: {
29
+ region: 'us-east-1',
30
+ maxAttempts: 5,
31
+ tablePrefix: 'proddebug-',
32
+ enableLogging: true,
33
+ readConsistency: 'eventual'
34
+ },
35
+ features: {
36
+ enableParallelProcessing: true,
37
+ enableBatchOperations: true,
38
+ enableCaching: true
39
+ },
40
+ monitoring: {
41
+ enableMetrics: true,
42
+ logLevel: 'info'
43
+ }
44
+ },
45
+ PROD: {
46
+ environment: 'PROD',
47
+ database: {
48
+ region: 'us-east-1',
49
+ maxAttempts: 10,
50
+ tablePrefix: '',
51
+ enableLogging: false,
52
+ readConsistency: 'strong'
53
+ },
54
+ features: {
55
+ enableParallelProcessing: true,
56
+ enableBatchOperations: true,
57
+ enableCaching: true
58
+ },
59
+ monitoring: {
60
+ enableMetrics: true,
61
+ logLevel: 'warn'
62
+ }
63
+ },
64
+ test: {
65
+ environment: 'test',
66
+ database: {
67
+ region: 'us-east-1',
68
+ endpoint: 'http://localhost:8000',
69
+ maxAttempts: 1,
70
+ tablePrefix: 'test-',
71
+ enableLogging: false,
72
+ readConsistency: 'eventual'
73
+ },
74
+ features: {
75
+ enableParallelProcessing: false,
76
+ enableBatchOperations: false,
77
+ enableCaching: false
78
+ },
79
+ monitoring: {
80
+ enableMetrics: false,
81
+ logLevel: 'error'
82
+ }
83
+ }
84
+ };
85
+ class EnvironmentManager {
86
+ constructor() {
87
+ this.currentConfig = this.loadEnvironmentConfig();
88
+ }
89
+ static getInstance() {
90
+ if (!EnvironmentManager.instance) {
91
+ EnvironmentManager.instance = new EnvironmentManager();
92
+ }
93
+ return EnvironmentManager.instance;
94
+ }
95
+ loadEnvironmentConfig() {
96
+ // Priority order: NODE_ENV -> ENVIRONMENT -> default to DEV
97
+ const env = (process.env.NODE_ENV || process.env.ENVIRONMENT || 'DEV');
98
+ if (!environmentConfigs[env]) {
99
+ console.warn(`Unknown environment: ${env}. Falling back to DEV.`);
100
+ return environmentConfigs.DEV;
101
+ }
102
+ return environmentConfigs[env];
103
+ }
104
+ getConfig() {
105
+ return this.currentConfig;
106
+ }
107
+ getDatabaseConfig() {
108
+ return this.currentConfig.database;
109
+ }
110
+ getEnvironment() {
111
+ return this.currentConfig.environment;
112
+ }
113
+ isDEV() {
114
+ return this.currentConfig.environment === 'DEV';
115
+ }
116
+ isPROD() {
117
+ return this.currentConfig.environment === 'PROD';
118
+ }
119
+ isPRODDEBUG() {
120
+ return this.currentConfig.environment === 'PRODDEBUG';
121
+ }
122
+ isTest() {
123
+ return this.currentConfig.environment === 'test';
124
+ }
125
+ // Method to override environment at runtime (useful for testing)
126
+ setEnvironment(environment) {
127
+ this.currentConfig = environmentConfigs[environment];
128
+ }
129
+ }
130
+ exports.EnvironmentManager = EnvironmentManager;
131
+ // Export singleton instance
132
+ exports.envManager = EnvironmentManager.getInstance();
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment-config.js","sourceRoot":"","sources":["../../src/config/environment-config.ts"],"names":[],"mappings":"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","sourcesContent":["export type Environment = 'DEV' | 'PRODDEBUG' | 'PROD' | 'test';\n\nexport interface DatabaseConfig {\n    region: string;\n    endpoint?: string;\n    maxAttempts: number;\n    tablePrefix: string;\n    enableLogging: boolean;\n    readConsistency: 'eventual' | 'strong';\n}\n\nexport interface EnvironmentConfig {\n    environment: Environment;\n    database: DatabaseConfig;\n    features: {\n        enableParallelProcessing: boolean;\n        enableBatchOperations: boolean;\n        enableCaching: boolean;\n    };\n    monitoring: {\n        enableMetrics: boolean;\n        logLevel: 'debug' | 'info' | 'warn' | 'error';\n    };\n}\n\n// Environment-specific configurations\nconst environmentConfigs: Record<Environment, EnvironmentConfig> = {\n    DEV: {\n        environment: 'DEV',\n        database: {\n            region: 'us-east-1',\n            endpoint: 'http://localhost:8000', // Local DynamoDB\n            maxAttempts: 3,\n            tablePrefix: 'dev-',\n            enableLogging: true,\n            readConsistency: 'eventual'\n        },\n        features: {\n            enableParallelProcessing: false,\n            enableBatchOperations: true,\n            enableCaching: false\n        },\n        monitoring: {\n            enableMetrics: false,\n            logLevel: 'debug'\n        }\n    },\n    PRODDEBUG: {\n        environment: 'PRODDEBUG',\n        database: {\n            region: 'us-east-1',\n            maxAttempts: 5,\n            tablePrefix: 'proddebug-',\n            enableLogging: true,\n            readConsistency: 'eventual'\n        },\n        features: {\n            enableParallelProcessing: true,\n            enableBatchOperations: true,\n            enableCaching: true\n        },\n        monitoring: {\n            enableMetrics: true,\n            logLevel: 'info'\n        }\n    },\n    PROD: {\n        environment: 'PROD',\n        database: {\n            region: 'us-east-1',\n            maxAttempts: 10,\n            tablePrefix: '',\n            enableLogging: false,\n            readConsistency: 'strong'\n        },\n        features: {\n            enableParallelProcessing: true,\n            enableBatchOperations: true,\n            enableCaching: true\n        },\n        monitoring: {\n            enableMetrics: true,\n            logLevel: 'warn'\n        }\n    },\n    test: {\n        environment: 'test',\n        database: {\n            region: 'us-east-1',\n            endpoint: 'http://localhost:8000',\n            maxAttempts: 1,\n            tablePrefix: 'test-',\n            enableLogging: false,\n            readConsistency: 'eventual'\n        },\n        features: {\n            enableParallelProcessing: false,\n            enableBatchOperations: false,\n            enableCaching: false\n        },\n        monitoring: {\n            enableMetrics: false,\n            logLevel: 'error'\n        }\n    }\n};\n\nexport class EnvironmentManager {\n    private static instance: EnvironmentManager;\n    private currentConfig: EnvironmentConfig;\n\n    private constructor() {\n        this.currentConfig = this.loadEnvironmentConfig();\n    }\n\n    public static getInstance(): EnvironmentManager {\n        if (!EnvironmentManager.instance) {\n            EnvironmentManager.instance = new EnvironmentManager();\n        }\n        return EnvironmentManager.instance;\n    }\n\n    private loadEnvironmentConfig(): EnvironmentConfig {\n        // Priority order: NODE_ENV -> ENVIRONMENT -> default to DEV\n        const env = (process.env.NODE_ENV || process.env.ENVIRONMENT || 'DEV') as Environment;\n\n        if (!environmentConfigs[env]) {\n            console.warn(`Unknown environment: ${env}. Falling back to DEV.`);\n            return environmentConfigs.DEV;\n        }\n\n        return environmentConfigs[env];\n    }\n\n    public getConfig(): EnvironmentConfig {\n        return this.currentConfig;\n    }\n\n    public getDatabaseConfig(): DatabaseConfig {\n        return this.currentConfig.database;\n    }\n\n    public getEnvironment(): Environment {\n        return this.currentConfig.environment;\n    }\n\n    public isDEV(): boolean {\n        return this.currentConfig.environment === 'DEV';\n    }\n\n    public isPROD(): boolean {\n        return this.currentConfig.environment === 'PROD';\n    }\n\n    public isPRODDEBUG(): boolean {\n        return this.currentConfig.environment === 'PRODDEBUG';\n    }\n\n    public isTest(): boolean {\n        return this.currentConfig.environment === 'test';\n    }\n\n    // Method to override environment at runtime (useful for testing)\n    public setEnvironment(environment: Environment): void {\n        this.currentConfig = environmentConfigs[environment];\n    }\n}\n\n// Export singleton instance\nexport const envManager = EnvironmentManager.getInstance();\n"]}
@@ -0,0 +1,3 @@
1
+ export * from './environment-config';
2
+ export * from './database-factory';
3
+ export * from './table-names';
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ // Export all configuration modules
18
+ __exportStar(require("./environment-config"), exports);
19
+ __exportStar(require("./database-factory"), exports);
20
+ __exportStar(require("./table-names"), exports);
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29uZmlnL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxtQ0FBbUM7QUFDbkMsdURBQXFDO0FBQ3JDLHFEQUFtQztBQUNuQyxnREFBOEIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBFeHBvcnQgYWxsIGNvbmZpZ3VyYXRpb24gbW9kdWxlc1xuZXhwb3J0ICogZnJvbSAnLi9lbnZpcm9ubWVudC1jb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhYmFzZS1mYWN0b3J5JztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUtbmFtZXMnO1xuIl19
@@ -0,0 +1,100 @@
1
+ export declare const BASE_TABLE_NAMES: {
2
+ readonly APP_FEEDBACK: "AppFeedbackTable";
3
+ readonly LSQ_CRM: "LsqCrmTable";
4
+ readonly CUTLERY: "CutleryTable";
5
+ readonly ITEM_ACCOMPANIMENTS: "ItemAccompanimentsTable";
6
+ readonly CUISINE: "CuisineTable";
7
+ readonly TIER_DETAILS: "TierDetailsTable";
8
+ readonly USER_ORDER_SUMMARY: "UserOrderSummaryTable";
9
+ readonly TIER_REFERRAL: "TierReferralTable";
10
+ readonly USER_ADDRESS_REQUEST: "UserAddressRequestTable";
11
+ readonly COMMON_FEEDBACK: "CommonFeedbackTable";
12
+ readonly GUEST_FEEDBACK: "GuestFeedbackTable";
13
+ readonly COUNTER: "CounterTable";
14
+ readonly REQUEST_INVOICE: "RequestInvoiceTable";
15
+ readonly PLATTER_SEARCH_EVENTS: "PlatterSearchEventsTable";
16
+ readonly ORDER_REVIEW_FEEDBACK: "OrderReviewFeedbackTable";
17
+ readonly CATERING_REQUEST: "CateringRequestTable";
18
+ readonly ORDER: "OrderTable";
19
+ readonly ORDER_ADDRESS: "OrderAddressTable";
20
+ readonly ORDER_REVIEW: "OrderReviewTable";
21
+ readonly PAYMENT: "PaymentTable";
22
+ readonly PLATE_ORDER: "PlateOrderTable";
23
+ readonly TRACKING: "TrackingTable";
24
+ readonly USER_ADDRESS: "UserAddressTable";
25
+ readonly ADD_ONS: "AddOnsTable";
26
+ readonly BANK_DETAILS: "BankDetailsTable";
27
+ readonly CART: "CartTable";
28
+ readonly CART_CATEGORIES: "CartCategoriesTable";
29
+ readonly CATEGORY: "CategoryTable";
30
+ readonly CATERING: "CateringTable";
31
+ readonly CONTENT: "ContentTable";
32
+ readonly COUPONS: "CouponsTable";
33
+ readonly DEFAULT_PLATTER: "DefaultPlatterTable";
34
+ readonly DEFAULT_PLATTER_CATEGORIES: "DefaultPlatterCategoriesTable";
35
+ readonly DEFAULT_PLATTER_ITEMS: "DefaultPlatterItemsTable";
36
+ readonly EVENT_EXECUTIVES: "EventExecutivesTable";
37
+ readonly ITEMS: "ItemsTable";
38
+ readonly LEAD: "LeadTable";
39
+ readonly OCCASION: "OccasionTable";
40
+ readonly REFERRAL_CONTENT: "ReferralContentTable";
41
+ readonly USER: "UserTable";
42
+ readonly WALLET: "WalletTable";
43
+ readonly WALLET_TRANSACTION: "WalletTransactionTable";
44
+ readonly WITHDRAWN: "WithdrawnTable";
45
+ readonly INTERNAL_USER: "InternalUserTable";
46
+ readonly ACTIVITY_LOGS: "ActivityLogsTable";
47
+ readonly QUOTATIONS: "QuotationsTable";
48
+ };
49
+ export declare class TableNameManager {
50
+ static getTableName(baseTableName: string): string;
51
+ static getAllTableNames(): Record<string, string>;
52
+ }
53
+ export declare const TABLE_NAMES: {
54
+ readonly APP_FEEDBACK: string;
55
+ readonly LSQ_CRM: string;
56
+ readonly CUTLERY: string;
57
+ readonly ITEM_ACCOMPANIMENTS: string;
58
+ readonly CUISINE: string;
59
+ readonly TIER_DETAILS: string;
60
+ readonly USER_ORDER_SUMMARY: string;
61
+ readonly TIER_REFERRAL: string;
62
+ readonly USER_ADDRESS_REQUEST: string;
63
+ readonly COMMON_FEEDBACK: string;
64
+ readonly GUEST_FEEDBACK: string;
65
+ readonly COUNTER: string;
66
+ readonly REQUEST_INVOICE: string;
67
+ readonly PLATTER_SEARCH_EVENTS: string;
68
+ readonly ORDER_REVIEW_FEEDBACK: string;
69
+ readonly CATERING_REQUEST: string;
70
+ readonly ORDER: string;
71
+ readonly ORDER_ADDRESS: string;
72
+ readonly ORDER_REVIEW: string;
73
+ readonly PAYMENT: string;
74
+ readonly PLATE_ORDER: string;
75
+ readonly TRACKING: string;
76
+ readonly USER_ADDRESS: string;
77
+ readonly ADD_ONS: string;
78
+ readonly BANK_DETAILS: string;
79
+ readonly CART: string;
80
+ readonly CART_CATEGORIES: string;
81
+ readonly CATEGORY: string;
82
+ readonly CATERING: string;
83
+ readonly CONTENT: string;
84
+ readonly COUPONS: string;
85
+ readonly DEFAULT_PLATTER: string;
86
+ readonly DEFAULT_PLATTER_CATEGORIES: string;
87
+ readonly DEFAULT_PLATTER_ITEMS: string;
88
+ readonly EVENT_EXECUTIVES: string;
89
+ readonly ITEMS: string;
90
+ readonly LEAD: string;
91
+ readonly OCCASION: string;
92
+ readonly REFERRAL_CONTENT: string;
93
+ readonly USER: string;
94
+ readonly WALLET: string;
95
+ readonly WALLET_TRANSACTION: string;
96
+ readonly WITHDRAWN: string;
97
+ readonly INTERNAL_USER: string;
98
+ readonly ACTIVITY_LOGS: string;
99
+ readonly QUOTATIONS: string;
100
+ };
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TABLE_NAMES = exports.TableNameManager = exports.BASE_TABLE_NAMES = void 0;
4
+ const database_factory_1 = require("./database-factory");
5
+ // Base table names (without environment prefix)
6
+ exports.BASE_TABLE_NAMES = {
7
+ // Customer App Tables
8
+ APP_FEEDBACK: 'AppFeedbackTable',
9
+ LSQ_CRM: 'LsqCrmTable',
10
+ CUTLERY: 'CutleryTable',
11
+ ITEM_ACCOMPANIMENTS: 'ItemAccompanimentsTable',
12
+ CUISINE: 'CuisineTable',
13
+ TIER_DETAILS: 'TierDetailsTable',
14
+ USER_ORDER_SUMMARY: 'UserOrderSummaryTable',
15
+ TIER_REFERRAL: 'TierReferralTable',
16
+ USER_ADDRESS_REQUEST: 'UserAddressRequestTable',
17
+ COMMON_FEEDBACK: 'CommonFeedbackTable',
18
+ GUEST_FEEDBACK: 'GuestFeedbackTable',
19
+ COUNTER: 'CounterTable',
20
+ REQUEST_INVOICE: 'RequestInvoiceTable',
21
+ PLATTER_SEARCH_EVENTS: 'PlatterSearchEventsTable',
22
+ ORDER_REVIEW_FEEDBACK: 'OrderReviewFeedbackTable',
23
+ CATERING_REQUEST: 'CateringRequestTable',
24
+ // Order Module Tables
25
+ ORDER: 'OrderTable',
26
+ ORDER_ADDRESS: 'OrderAddressTable',
27
+ ORDER_REVIEW: 'OrderReviewTable',
28
+ PAYMENT: 'PaymentTable',
29
+ PLATE_ORDER: 'PlateOrderTable',
30
+ TRACKING: 'TrackingTable',
31
+ USER_ADDRESS: 'UserAddressTable',
32
+ // Other Customer Tables
33
+ ADD_ONS: 'AddOnsTable',
34
+ BANK_DETAILS: 'BankDetailsTable',
35
+ CART: 'CartTable',
36
+ CART_CATEGORIES: 'CartCategoriesTable',
37
+ CATEGORY: 'CategoryTable',
38
+ CATERING: 'CateringTable',
39
+ CONTENT: 'ContentTable',
40
+ COUPONS: 'CouponsTable',
41
+ DEFAULT_PLATTER: 'DefaultPlatterTable',
42
+ DEFAULT_PLATTER_CATEGORIES: 'DefaultPlatterCategoriesTable',
43
+ DEFAULT_PLATTER_ITEMS: 'DefaultPlatterItemsTable',
44
+ EVENT_EXECUTIVES: 'EventExecutivesTable',
45
+ ITEMS: 'ItemsTable',
46
+ LEAD: 'LeadTable',
47
+ OCCASION: 'OccasionTable',
48
+ REFERRAL_CONTENT: 'ReferralContentTable',
49
+ USER: 'UserTable',
50
+ WALLET: 'WalletTable',
51
+ WALLET_TRANSACTION: 'WalletTransactionTable',
52
+ WITHDRAWN: 'WithdrawnTable',
53
+ // Internal User Tables
54
+ INTERNAL_USER: 'InternalUserTable',
55
+ ACTIVITY_LOGS: 'ActivityLogsTable',
56
+ QUOTATIONS: 'QuotationsTable'
57
+ };
58
+ // Environment-aware table name getter
59
+ class TableNameManager {
60
+ static getTableName(baseTableName) {
61
+ return database_factory_1.DatabaseFactory.getTableName(baseTableName);
62
+ }
63
+ static getAllTableNames() {
64
+ const tableNames = {};
65
+ Object.entries(exports.BASE_TABLE_NAMES).forEach(([key, value]) => {
66
+ tableNames[key] = this.getTableName(value);
67
+ });
68
+ return tableNames;
69
+ }
70
+ }
71
+ exports.TableNameManager = TableNameManager;
72
+ // Export environment-aware table names
73
+ exports.TABLE_NAMES = {
74
+ // Customer App Tables
75
+ APP_FEEDBACK: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.APP_FEEDBACK),
76
+ LSQ_CRM: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.LSQ_CRM),
77
+ CUTLERY: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CUTLERY),
78
+ ITEM_ACCOMPANIMENTS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ITEM_ACCOMPANIMENTS),
79
+ CUISINE: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CUISINE),
80
+ TIER_DETAILS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.TIER_DETAILS),
81
+ USER_ORDER_SUMMARY: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.USER_ORDER_SUMMARY),
82
+ TIER_REFERRAL: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.TIER_REFERRAL),
83
+ USER_ADDRESS_REQUEST: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.USER_ADDRESS_REQUEST),
84
+ COMMON_FEEDBACK: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.COMMON_FEEDBACK),
85
+ GUEST_FEEDBACK: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.GUEST_FEEDBACK),
86
+ COUNTER: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.COUNTER),
87
+ REQUEST_INVOICE: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.REQUEST_INVOICE),
88
+ PLATTER_SEARCH_EVENTS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.PLATTER_SEARCH_EVENTS),
89
+ ORDER_REVIEW_FEEDBACK: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ORDER_REVIEW_FEEDBACK),
90
+ CATERING_REQUEST: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CATERING_REQUEST),
91
+ // Order Module Tables
92
+ ORDER: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ORDER),
93
+ ORDER_ADDRESS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ORDER_ADDRESS),
94
+ ORDER_REVIEW: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ORDER_REVIEW),
95
+ PAYMENT: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.PAYMENT),
96
+ PLATE_ORDER: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.PLATE_ORDER),
97
+ TRACKING: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.TRACKING),
98
+ USER_ADDRESS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.USER_ADDRESS),
99
+ // Other Customer Tables
100
+ ADD_ONS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ADD_ONS),
101
+ BANK_DETAILS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.BANK_DETAILS),
102
+ CART: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CART),
103
+ CART_CATEGORIES: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CART_CATEGORIES),
104
+ CATEGORY: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CATEGORY),
105
+ CATERING: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CATERING),
106
+ CONTENT: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CONTENT),
107
+ COUPONS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.COUPONS),
108
+ DEFAULT_PLATTER: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.DEFAULT_PLATTER),
109
+ DEFAULT_PLATTER_CATEGORIES: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.DEFAULT_PLATTER_CATEGORIES),
110
+ DEFAULT_PLATTER_ITEMS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.DEFAULT_PLATTER_ITEMS),
111
+ EVENT_EXECUTIVES: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.EVENT_EXECUTIVES),
112
+ ITEMS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ITEMS),
113
+ LEAD: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.LEAD),
114
+ OCCASION: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.OCCASION),
115
+ REFERRAL_CONTENT: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.REFERRAL_CONTENT),
116
+ USER: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.USER),
117
+ WALLET: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.WALLET),
118
+ WALLET_TRANSACTION: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.WALLET_TRANSACTION),
119
+ WITHDRAWN: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.WITHDRAWN),
120
+ // Internal User Tables
121
+ INTERNAL_USER: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.INTERNAL_USER),
122
+ ACTIVITY_LOGS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ACTIVITY_LOGS),
123
+ QUOTATIONS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.QUOTATIONS)
124
+ };
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-names.js","sourceRoot":"","sources":["../../src/config/table-names.ts"],"names":[],"mappings":";;;AAAA,yDAAqD;AAErD,gDAAgD;AACnC,QAAA,gBAAgB,GAAG;IAC5B,sBAAsB;IACtB,YAAY,EAAE,kBAAkB;IAChC,OAAO,EAAE,aAAa;IACtB,OAAO,EAAE,cAAc;IACvB,mBAAmB,EAAE,yBAAyB;IAC9C,OAAO,EAAE,cAAc;IACvB,YAAY,EAAE,kBAAkB;IAChC,kBAAkB,EAAE,uBAAuB;IAC3C,aAAa,EAAE,mBAAmB;IAClC,oBAAoB,EAAE,yBAAyB;IAC/C,eAAe,EAAE,qBAAqB;IACtC,cAAc,EAAE,oBAAoB;IACpC,OAAO,EAAE,cAAc;IACvB,eAAe,EAAE,qBAAqB;IACtC,qBAAqB,EAAE,0BAA0B;IACjD,qBAAqB,EAAE,0BAA0B;IACjD,gBAAgB,EAAE,sBAAsB;IAExC,sBAAsB;IACtB,KAAK,EAAE,YAAY;IACnB,aAAa,EAAE,mBAAmB;IAClC,YAAY,EAAE,kBAAkB;IAChC,OAAO,EAAE,cAAc;IACvB,WAAW,EAAE,iBAAiB;IAC9B,QAAQ,EAAE,eAAe;IACzB,YAAY,EAAE,kBAAkB;IAEhC,wBAAwB;IACxB,OAAO,EAAE,aAAa;IACtB,YAAY,EAAE,kBAAkB;IAChC,IAAI,EAAE,WAAW;IACjB,eAAe,EAAE,qBAAqB;IACtC,QAAQ,EAAE,eAAe;IACzB,QAAQ,EAAE,eAAe;IACzB,OAAO,EAAE,cAAc;IACvB,OAAO,EAAE,cAAc;IACvB,eAAe,EAAE,qBAAqB;IACtC,0BAA0B,EAAE,+BAA+B;IAC3D,qBAAqB,EAAE,0BAA0B;IACjD,gBAAgB,EAAE,sBAAsB;IACxC,KAAK,EAAE,YAAY;IACnB,IAAI,EAAE,WAAW;IACjB,QAAQ,EAAE,eAAe;IACzB,gBAAgB,EAAE,sBAAsB;IACxC,IAAI,EAAE,WAAW;IACjB,MAAM,EAAE,aAAa;IACrB,kBAAkB,EAAE,wBAAwB;IAC5C,SAAS,EAAE,gBAAgB;IAE3B,uBAAuB;IACvB,aAAa,EAAE,mBAAmB;IAClC,aAAa,EAAE,mBAAmB;IAClC,UAAU,EAAE,iBAAiB;CACvB,CAAC;AAEX,sCAAsC;AACtC,MAAa,gBAAgB;IAClB,MAAM,CAAC,YAAY,CAAC,aAAqB;QAC5C,OAAO,kCAAe,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAEM,MAAM,CAAC,gBAAgB;QAC1B,MAAM,UAAU,GAA2B,EAAE,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,wBAAgB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YACtD,UAAU,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,OAAO,UAAU,CAAC;IACtB,CAAC;CACJ;AAdD,4CAcC;AAED,uCAAuC;AAC1B,QAAA,WAAW,GAAG;IACvB,sBAAsB;IACtB,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,mBAAmB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,mBAAmB,CAAC;IACxF,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,kBAAkB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,kBAAkB,CAAC;IACtF,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,oBAAoB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,oBAAoB,CAAC;IAC1F,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,cAAc,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,cAAc,CAAC;IAC9E,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,qBAAqB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,qBAAqB,CAAC;IAC5F,qBAAqB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,qBAAqB,CAAC;IAC5F,gBAAgB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,gBAAgB,CAAC;IAElF,sBAAsB;IACtB,KAAK,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,KAAK,CAAC;IAC5D,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,WAAW,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,WAAW,CAAC;IACxE,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAE1E,wBAAwB;IACxB,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,IAAI,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,IAAI,CAAC;IAC1D,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,0BAA0B,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,0BAA0B,CAAC;IACtG,qBAAqB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,qBAAqB,CAAC;IAC5F,gBAAgB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,gBAAgB,CAAC;IAClF,KAAK,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,KAAK,CAAC;IAC5D,IAAI,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,IAAI,CAAC;IAC1D,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,gBAAgB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,gBAAgB,CAAC;IAClF,IAAI,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,IAAI,CAAC;IAC1D,MAAM,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,MAAM,CAAC;IAC9D,kBAAkB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,kBAAkB,CAAC;IACtF,SAAS,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,SAAS,CAAC;IAEpE,uBAAuB;IACvB,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,UAAU,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,UAAU,CAAC;CAChE,CAAC","sourcesContent":["import { DatabaseFactory } from './database-factory';\n\n// Base table names (without environment prefix)\nexport const BASE_TABLE_NAMES = {\n    // Customer App Tables\n    APP_FEEDBACK: 'AppFeedbackTable',\n    LSQ_CRM: 'LsqCrmTable',\n    CUTLERY: 'CutleryTable',\n    ITEM_ACCOMPANIMENTS: 'ItemAccompanimentsTable',\n    CUISINE: 'CuisineTable',\n    TIER_DETAILS: 'TierDetailsTable',\n    USER_ORDER_SUMMARY: 'UserOrderSummaryTable',\n    TIER_REFERRAL: 'TierReferralTable',\n    USER_ADDRESS_REQUEST: 'UserAddressRequestTable',\n    COMMON_FEEDBACK: 'CommonFeedbackTable',\n    GUEST_FEEDBACK: 'GuestFeedbackTable',\n    COUNTER: 'CounterTable',\n    REQUEST_INVOICE: 'RequestInvoiceTable',\n    PLATTER_SEARCH_EVENTS: 'PlatterSearchEventsTable',\n    ORDER_REVIEW_FEEDBACK: 'OrderReviewFeedbackTable',\n    CATERING_REQUEST: 'CateringRequestTable',\n\n    // Order Module Tables\n    ORDER: 'OrderTable',\n    ORDER_ADDRESS: 'OrderAddressTable',\n    ORDER_REVIEW: 'OrderReviewTable',\n    PAYMENT: 'PaymentTable',\n    PLATE_ORDER: 'PlateOrderTable',\n    TRACKING: 'TrackingTable',\n    USER_ADDRESS: 'UserAddressTable',\n\n    // Other Customer Tables\n    ADD_ONS: 'AddOnsTable',\n    BANK_DETAILS: 'BankDetailsTable',\n    CART: 'CartTable',\n    CART_CATEGORIES: 'CartCategoriesTable',\n    CATEGORY: 'CategoryTable',\n    CATERING: 'CateringTable',\n    CONTENT: 'ContentTable',\n    COUPONS: 'CouponsTable',\n    DEFAULT_PLATTER: 'DefaultPlatterTable',\n    DEFAULT_PLATTER_CATEGORIES: 'DefaultPlatterCategoriesTable',\n    DEFAULT_PLATTER_ITEMS: 'DefaultPlatterItemsTable',\n    EVENT_EXECUTIVES: 'EventExecutivesTable',\n    ITEMS: 'ItemsTable',\n    LEAD: 'LeadTable',\n    OCCASION: 'OccasionTable',\n    REFERRAL_CONTENT: 'ReferralContentTable',\n    USER: 'UserTable',\n    WALLET: 'WalletTable',\n    WALLET_TRANSACTION: 'WalletTransactionTable',\n    WITHDRAWN: 'WithdrawnTable',\n\n    // Internal User Tables\n    INTERNAL_USER: 'InternalUserTable',\n    ACTIVITY_LOGS: 'ActivityLogsTable',\n    QUOTATIONS: 'QuotationsTable'\n} as const;\n\n// Environment-aware table name getter\nexport class TableNameManager {\n    public static getTableName(baseTableName: string): string {\n        return DatabaseFactory.getTableName(baseTableName);\n    }\n\n    public static getAllTableNames(): Record<string, string> {\n        const tableNames: Record<string, string> = {};\n\n        Object.entries(BASE_TABLE_NAMES).forEach(([key, value]) => {\n            tableNames[key] = this.getTableName(value);\n        });\n\n        return tableNames;\n    }\n}\n\n// Export environment-aware table names\nexport const TABLE_NAMES = {\n    // Customer App Tables\n    APP_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.APP_FEEDBACK),\n    LSQ_CRM: TableNameManager.getTableName(BASE_TABLE_NAMES.LSQ_CRM),\n    CUTLERY: TableNameManager.getTableName(BASE_TABLE_NAMES.CUTLERY),\n    ITEM_ACCOMPANIMENTS: TableNameManager.getTableName(BASE_TABLE_NAMES.ITEM_ACCOMPANIMENTS),\n    CUISINE: TableNameManager.getTableName(BASE_TABLE_NAMES.CUISINE),\n    TIER_DETAILS: TableNameManager.getTableName(BASE_TABLE_NAMES.TIER_DETAILS),\n    USER_ORDER_SUMMARY: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ORDER_SUMMARY),\n    TIER_REFERRAL: TableNameManager.getTableName(BASE_TABLE_NAMES.TIER_REFERRAL),\n    USER_ADDRESS_REQUEST: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ADDRESS_REQUEST),\n    COMMON_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.COMMON_FEEDBACK),\n    GUEST_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.GUEST_FEEDBACK),\n    COUNTER: TableNameManager.getTableName(BASE_TABLE_NAMES.COUNTER),\n    REQUEST_INVOICE: TableNameManager.getTableName(BASE_TABLE_NAMES.REQUEST_INVOICE),\n    PLATTER_SEARCH_EVENTS: TableNameManager.getTableName(BASE_TABLE_NAMES.PLATTER_SEARCH_EVENTS),\n    ORDER_REVIEW_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_REVIEW_FEEDBACK),\n    CATERING_REQUEST: TableNameManager.getTableName(BASE_TABLE_NAMES.CATERING_REQUEST),\n\n    // Order Module Tables\n    ORDER: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER),\n    ORDER_ADDRESS: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_ADDRESS),\n    ORDER_REVIEW: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_REVIEW),\n    PAYMENT: TableNameManager.getTableName(BASE_TABLE_NAMES.PAYMENT),\n    PLATE_ORDER: TableNameManager.getTableName(BASE_TABLE_NAMES.PLATE_ORDER),\n    TRACKING: TableNameManager.getTableName(BASE_TABLE_NAMES.TRACKING),\n    USER_ADDRESS: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ADDRESS),\n\n    // Other Customer Tables\n    ADD_ONS: TableNameManager.getTableName(BASE_TABLE_NAMES.ADD_ONS),\n    BANK_DETAILS: TableNameManager.getTableName(BASE_TABLE_NAMES.BANK_DETAILS),\n    CART: TableNameManager.getTableName(BASE_TABLE_NAMES.CART),\n    CART_CATEGORIES: TableNameManager.getTableName(BASE_TABLE_NAMES.CART_CATEGORIES),\n    CATEGORY: TableNameManager.getTableName(BASE_TABLE_NAMES.CATEGORY),\n    CATERING: TableNameManager.getTableName(BASE_TABLE_NAMES.CATERING),\n    CONTENT: TableNameManager.getTableName(BASE_TABLE_NAMES.CONTENT),\n    COUPONS: TableNameManager.getTableName(BASE_TABLE_NAMES.COUPONS),\n    DEFAULT_PLATTER: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER),\n    DEFAULT_PLATTER_CATEGORIES: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER_CATEGORIES),\n    DEFAULT_PLATTER_ITEMS: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER_ITEMS),\n    EVENT_EXECUTIVES: TableNameManager.getTableName(BASE_TABLE_NAMES.EVENT_EXECUTIVES),\n    ITEMS: TableNameManager.getTableName(BASE_TABLE_NAMES.ITEMS),\n    LEAD: TableNameManager.getTableName(BASE_TABLE_NAMES.LEAD),\n    OCCASION: TableNameManager.getTableName(BASE_TABLE_NAMES.OCCASION),\n    REFERRAL_CONTENT: TableNameManager.getTableName(BASE_TABLE_NAMES.REFERRAL_CONTENT),\n    USER: TableNameManager.getTableName(BASE_TABLE_NAMES.USER),\n    WALLET: TableNameManager.getTableName(BASE_TABLE_NAMES.WALLET),\n    WALLET_TRANSACTION: TableNameManager.getTableName(BASE_TABLE_NAMES.WALLET_TRANSACTION),\n    WITHDRAWN: TableNameManager.getTableName(BASE_TABLE_NAMES.WITHDRAWN),\n\n    // Internal User Tables\n    INTERNAL_USER: TableNameManager.getTableName(BASE_TABLE_NAMES.INTERNAL_USER),\n    ACTIVITY_LOGS: TableNameManager.getTableName(BASE_TABLE_NAMES.ACTIVITY_LOGS),\n    QUOTATIONS: TableNameManager.getTableName(BASE_TABLE_NAMES.QUOTATIONS)\n} as const;\n"]}
@@ -22,7 +22,7 @@ __decorate([
22
22
  (0, annotations_1.attribute)()
23
23
  ], TierRefererModel.prototype, "referralName", void 0);
24
24
  __decorate([
25
- (0, annotations_1.attribute)()
25
+ (0, annotations_1.attribute)({ indexKeyConfigurations: { "sentToIndex": "HASH" }, type: 'String' })
26
26
  ], TierRefererModel.prototype, "sentTo", void 0);
27
27
  __decorate([
28
28
  (0, annotations_1.attribute)()
@@ -36,4 +36,4 @@ __decorate([
36
36
  exports.TierRefererModel = TierRefererModel = __decorate([
37
37
  (0, annotations_1.table)("TierReferralTable")
38
38
  ], TierRefererModel);
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGllci1yZWZlcnJhbC1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXN0b21lci11c2VyL3RpZXItcmVmZXJyYWwvdGllci1yZWZlcnJhbC1tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSx1REFBK0U7QUFDL0UsaURBQTZDO0FBR3RDLElBQU0sZ0JBQWdCLEdBQXRCLE1BQU0sZ0JBQWlCLFNBQVEsc0JBQVM7Q0FxQjlDLENBQUE7QUFyQlksNENBQWdCO0FBRXpCO0lBREMsSUFBQSxrQ0FBb0IsRUFBQyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsQ0FBQzt3REFDbEI7QUFHdkI7SUFEQyxJQUFBLHVCQUFTLEVBQUMsRUFBRSxzQkFBc0IsRUFBRSxFQUFFLGFBQWEsRUFBRSxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLENBQUM7Z0RBQ2xFO0FBR2Y7SUFEQyxJQUFBLHVCQUFTLEdBQUU7c0RBQ1U7QUFHdEI7SUFEQyxJQUFBLHVCQUFTLEdBQUU7Z0RBQ0c7QUFHZjtJQURDLElBQUEsdUJBQVMsR0FBRTtnREFDRztBQUdmO0lBREMsSUFBQSx1QkFBUyxHQUFFO3NEQUNTO0FBR3JCO0lBREMsSUFBQSx1QkFBUyxFQUFDLEVBQUUsc0JBQXNCLEVBQUUsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLENBQUM7cURBQ2xFOzJCQXBCWCxnQkFBZ0I7SUFENUIsSUFBQSxtQkFBSyxFQUFDLG1CQUFtQixDQUFDO0dBQ2QsZ0JBQWdCLENBcUI1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGF0dHJpYnV0ZSwgYXV0b0dlbmVyYXRlZEhhc2hLZXksIHRhYmxlIH0gZnJvbSBcIkBub3ZhLW9kbS9hbm5vdGF0aW9uc1wiO1xuaW1wb3J0IHsgQmFzZU1vZGVsIH0gZnJvbSBcIi4uLy4uL2Jhc2UtbW9kZWxcIjtcblxuQHRhYmxlKFwiVGllclJlZmVycmFsVGFibGVcIilcbmV4cG9ydCBjbGFzcyBUaWVyUmVmZXJlck1vZGVsIGV4dGVuZHMgQmFzZU1vZGVsIHtcbiAgICBAYXV0b0dlbmVyYXRlZEhhc2hLZXkoeyB0eXBlOiAnU3RyaW5nJyB9KVxuICAgIHRpZXJSZWZlcnJhbElkOiBzdHJpbmc7XG5cbiAgICBAYXR0cmlidXRlKHsgaW5kZXhLZXlDb25maWd1cmF0aW9uczogeyBcInVzZXJJZEluZGV4XCI6IFwiSEFTSFwiIH0sIHR5cGU6ICdTdHJpbmcnIH0pXG4gICAgdXNlcklkOiBzdHJpbmc7XG5cbiAgICBAYXR0cmlidXRlKClcbiAgICByZWZlcnJhbE5hbWU/OiBzdHJpbmc7XG5cbiAgICBAYXR0cmlidXRlKClcbiAgICBzZW50VG86IHN0cmluZzsgLy8gTW9iaWxlIE51bWJlclxuXG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgc3RhdHVzOiBzdHJpbmc7IC8vIFJFUVVFU1RFRCwgSk9JTkVELCBFQVJORURcblxuICAgIEBhdHRyaWJ1dGUoKVxuICAgIHNlbmRlZEFtb3VudDogbnVtYmVyOyAvLyBWMiBVcGRhdGUgdG8gcGFzcyBhY3R1YWwgc2VudCBhbW91bnQgZm9yIHNpZ25VcCtvcmRlcnZhbHVlIDEwJVxuXG4gICAgQGF0dHJpYnV0ZSh7IGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJhcHBsaWVkQ29kZUluZGV4XCI6IFwiSEFTSFwiIH0sIHR5cGU6ICdTdHJpbmcnIH0pXG4gICAgYXBwbGllZENvZGU6IHN0cmluZzsgLy8gQXBwbGllZCBDb2RlXG59Il19
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGllci1yZWZlcnJhbC1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXN0b21lci11c2VyL3RpZXItcmVmZXJyYWwvdGllci1yZWZlcnJhbC1tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSx1REFBK0U7QUFDL0UsaURBQTZDO0FBR3RDLElBQU0sZ0JBQWdCLEdBQXRCLE1BQU0sZ0JBQWlCLFNBQVEsc0JBQVM7Q0FxQjlDLENBQUE7QUFyQlksNENBQWdCO0FBRXpCO0lBREMsSUFBQSxrQ0FBb0IsRUFBQyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsQ0FBQzt3REFDbEI7QUFHdkI7SUFEQyxJQUFBLHVCQUFTLEVBQUMsRUFBRSxzQkFBc0IsRUFBRSxFQUFFLGFBQWEsRUFBRSxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLENBQUM7Z0RBQ2xFO0FBR2Y7SUFEQyxJQUFBLHVCQUFTLEdBQUU7c0RBQ1U7QUFHdEI7SUFEQyxJQUFBLHVCQUFTLEVBQUMsRUFBRSxzQkFBc0IsRUFBRSxFQUFFLGFBQWEsRUFBRSxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLENBQUM7Z0RBQ2xFO0FBR2Y7SUFEQyxJQUFBLHVCQUFTLEdBQUU7Z0RBQ0c7QUFHZjtJQURDLElBQUEsdUJBQVMsR0FBRTtzREFDUztBQUdyQjtJQURDLElBQUEsdUJBQVMsRUFBQyxFQUFFLHNCQUFzQixFQUFFLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxFQUFFLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxDQUFDO3FEQUNsRTsyQkFwQlgsZ0JBQWdCO0lBRDVCLElBQUEsbUJBQUssRUFBQyxtQkFBbUIsQ0FBQztHQUNkLGdCQUFnQixDQXFCNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhdHRyaWJ1dGUsIGF1dG9HZW5lcmF0ZWRIYXNoS2V5LCB0YWJsZSB9IGZyb20gXCJAbm92YS1vZG0vYW5ub3RhdGlvbnNcIjtcbmltcG9ydCB7IEJhc2VNb2RlbCB9IGZyb20gXCIuLi8uLi9iYXNlLW1vZGVsXCI7XG5cbkB0YWJsZShcIlRpZXJSZWZlcnJhbFRhYmxlXCIpXG5leHBvcnQgY2xhc3MgVGllclJlZmVyZXJNb2RlbCBleHRlbmRzIEJhc2VNb2RlbCB7XG4gICAgQGF1dG9HZW5lcmF0ZWRIYXNoS2V5KHsgdHlwZTogJ1N0cmluZycgfSlcbiAgICB0aWVyUmVmZXJyYWxJZDogc3RyaW5nO1xuXG4gICAgQGF0dHJpYnV0ZSh7IGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJ1c2VySWRJbmRleFwiOiBcIkhBU0hcIiB9LCB0eXBlOiAnU3RyaW5nJyB9KVxuICAgIHVzZXJJZDogc3RyaW5nO1xuXG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgcmVmZXJyYWxOYW1lPzogc3RyaW5nO1xuXG4gICAgQGF0dHJpYnV0ZSh7IGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJzZW50VG9JbmRleFwiOiBcIkhBU0hcIiB9LCB0eXBlOiAnU3RyaW5nJyB9KVxuICAgIHNlbnRUbzogc3RyaW5nOyAvLyBNb2JpbGUgTnVtYmVyXG5cbiAgICBAYXR0cmlidXRlKClcbiAgICBzdGF0dXM6IHN0cmluZzsgLy8gUkVRVUVTVEVELCBKT0lORUQsIEVBUk5FRFxuXG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgc2VuZGVkQW1vdW50OiBudW1iZXI7IC8vIFYyIFVwZGF0ZSB0byBwYXNzIGFjdHVhbCBzZW50IGFtb3VudCBmb3Igc2lnblVwK29yZGVydmFsdWUgMTAlXG5cbiAgICBAYXR0cmlidXRlKHsgaW5kZXhLZXlDb25maWd1cmF0aW9uczogeyBcImFwcGxpZWRDb2RlSW5kZXhcIjogXCJIQVNIXCIgfSwgdHlwZTogJ1N0cmluZycgfSlcbiAgICBhcHBsaWVkQ29kZTogc3RyaW5nOyAvLyBBcHBsaWVkIENvZGVcbn0iXX0=
package/index.js CHANGED
@@ -1,3 +1,9 @@
1
+ // Environment Configuration
2
+ export { envManager, EnvironmentManager } from './dist/config/environment-config';
3
+ export { DatabaseFactory } from './dist/config/database-factory';
4
+ export { TableNameManager, TABLE_NAMES, BASE_TABLE_NAMES } from './dist/config/table-names';
5
+
6
+ // Core Database Components
1
7
  export { InternalUserModel } from './dist/internal-user/internal-user-model';
2
8
  export { internalUserDao } from './dist/internal-user/internal-user-dao';
3
9
  export { GenericDAO } from './dist/base-dao';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cmp-aws-database",
3
- "version": "1.1.106",
3
+ "version": "1.1.107-dev.1",
4
4
  "bin": {
5
5
  "craft-my-plate-database": "bin/craft-my-plate-database.js"
6
6
  },
@@ -8,7 +8,17 @@
8
8
  "build": "tsc",
9
9
  "watch": "tsc -w",
10
10
  "test": "jest",
11
- "cdk": "cdk"
11
+ "cdk": "cdk",
12
+ "version:info": "node scripts/version-strategy.js info",
13
+ "version:increment": "node scripts/version-strategy.js increment",
14
+ "version:sync": "node scripts/version-strategy.js sync",
15
+ "deploy:dev": "./scripts/deploy-environment.sh -e DEV",
16
+ "deploy:proddebug": "./scripts/deploy-environment.sh -e PRODDEBUG",
17
+ "deploy:prod": "./scripts/deploy-environment.sh -e PROD",
18
+ "deploy:dev:skip-tests": "./scripts/deploy-environment.sh -e DEV --skip-tests",
19
+ "deploy:proddebug:skip-tests": "./scripts/deploy-environment.sh -e PRODDEBUG --skip-tests",
20
+ "deploy:prod:skip-tests": "./scripts/deploy-environment.sh -e PROD --skip-tests",
21
+ "create-branches": "./scripts/create-environment-branches.sh"
12
22
  },
13
23
  "devDependencies": {
14
24
  "@types/jest": "^29.5.14",
@@ -1,6 +0,0 @@
1
- import { GenericDAO } from "../../../base-dao";
2
- import { PaymentModel } from "./payment-model";
3
- declare class PaymentDAO extends GenericDAO<PaymentModel> {
4
- }
5
- export declare const paymentDao: PaymentDAO;
6
- export {};
@@ -1,8 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.paymentDao = void 0;
4
- const base_dao_1 = require("../../../base-dao");
5
- class PaymentDAO extends base_dao_1.GenericDAO {
6
- }
7
- exports.paymentDao = new PaymentDAO();
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWV0LWRhby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jdXN0b21lci11c2VyL29yZGVyLW1vZHVsZS9wYXltZW50L3BheW1ldC1kYW8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsZ0RBQStDO0FBRy9DLE1BQU0sVUFBVyxTQUFRLHFCQUF3QjtDQUVoRDtBQUVZLFFBQUEsVUFBVSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHZW5lcmljREFPIH0gZnJvbSBcIi4uLy4uLy4uL2Jhc2UtZGFvXCI7XG5pbXBvcnQgeyBQYXltZW50TW9kZWwgfSBmcm9tIFwiLi9wYXltZW50LW1vZGVsXCI7XG5cbmNsYXNzIFBheW1lbnREQU8gZXh0ZW5kcyBHZW5lcmljREFPPFBheW1lbnRNb2RlbD4ge1xuXG59XG5cbmV4cG9ydCBjb25zdCBwYXltZW50RGFvID0gbmV3IFBheW1lbnREQU8oKTsiXX0=