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 +228 -10
- package/dist/base-dao.d.ts +2 -1
- package/dist/base-dao.js +22 -11
- package/dist/config/database-factory.d.ts +12 -0
- package/dist/config/database-factory.js +43 -0
- package/dist/config/environment-config.d.ts +38 -0
- package/dist/config/environment-config.js +133 -0
- package/dist/config/index.d.ts +3 -0
- package/dist/config/index.js +21 -0
- package/dist/config/table-names.d.ts +100 -0
- package/dist/config/table-names.js +125 -0
- package/dist/customer-user/tier-referral/tier-referral-model.js +2 -2
- package/index.js +6 -0
- package/package.json +12 -2
- package/dist/customer-user/order-module/payment/paymet-dao.d.ts +0 -6
- package/dist/customer-user/order-module/payment/paymet-dao.js +0 -8
package/README.md
CHANGED
|
@@ -1,14 +1,232 @@
|
|
|
1
|
-
#
|
|
1
|
+
# Craft My Plate Database Package
|
|
2
2
|
|
|
3
|
-
|
|
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
|
-
|
|
5
|
+
## 🚀 Features
|
|
6
6
|
|
|
7
|
-
|
|
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
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
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.
|
package/dist/base-dao.d.ts
CHANGED
|
@@ -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:
|
|
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
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
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
|
|
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:
|
|
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
|
|
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:
|
|
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,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":"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","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,
|
|
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.
|
|
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,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=
|