@qrvey/data-persistence 0.0.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.
Files changed (81) hide show
  1. package/README.md +77 -0
  2. package/dist/cjs/helpers/crudHelpers.js +27 -0
  3. package/dist/cjs/helpers/crudHelpers.js.map +1 -0
  4. package/dist/cjs/helpers/queryHelpers.js +10 -0
  5. package/dist/cjs/helpers/queryHelpers.js.map +1 -0
  6. package/dist/cjs/helpers/tableHelper.js +25 -0
  7. package/dist/cjs/helpers/tableHelper.js.map +1 -0
  8. package/dist/cjs/index.js +15 -0
  9. package/dist/cjs/index.js.map +1 -0
  10. package/dist/cjs/interfaces/compoundFilter.interface.js +3 -0
  11. package/dist/cjs/interfaces/compoundFilter.interface.js.map +1 -0
  12. package/dist/cjs/interfaces/crudService.interface.js +3 -0
  13. package/dist/cjs/interfaces/crudService.interface.js.map +1 -0
  14. package/dist/cjs/interfaces/filter.interface.js +3 -0
  15. package/dist/cjs/interfaces/filter.interface.js.map +1 -0
  16. package/dist/cjs/interfaces/findIndex.interface.js +3 -0
  17. package/dist/cjs/interfaces/findIndex.interface.js.map +1 -0
  18. package/dist/cjs/interfaces/findOptions.interface.js +3 -0
  19. package/dist/cjs/interfaces/findOptions.interface.js.map +1 -0
  20. package/dist/cjs/interfaces/findPagination.interface.js +3 -0
  21. package/dist/cjs/interfaces/findPagination.interface.js.map +1 -0
  22. package/dist/cjs/interfaces/findResult.interface.js +3 -0
  23. package/dist/cjs/interfaces/findResult.interface.js.map +1 -0
  24. package/dist/cjs/interfaces/index.js +29 -0
  25. package/dist/cjs/interfaces/index.js.map +1 -0
  26. package/dist/cjs/interfaces/queryBuilder.interface.js +3 -0
  27. package/dist/cjs/interfaces/queryBuilder.interface.js.map +1 -0
  28. package/dist/cjs/interfaces/queryBuilderCondition.interface.js +3 -0
  29. package/dist/cjs/interfaces/queryBuilderCondition.interface.js.map +1 -0
  30. package/dist/cjs/interfaces/queryOptions.interface.js +3 -0
  31. package/dist/cjs/interfaces/queryOptions.interface.js.map +1 -0
  32. package/dist/cjs/interfaces/sorting.interface.js +3 -0
  33. package/dist/cjs/interfaces/sorting.interface.js.map +1 -0
  34. package/dist/cjs/interfaces/tableColumns.interface.js +3 -0
  35. package/dist/cjs/interfaces/tableColumns.interface.js.map +1 -0
  36. package/dist/cjs/interfaces/tableName.interface.js +3 -0
  37. package/dist/cjs/interfaces/tableName.interface.js.map +1 -0
  38. package/dist/cjs/interfaces/updateOptions.interface.js +3 -0
  39. package/dist/cjs/interfaces/updateOptions.interface.js.map +1 -0
  40. package/dist/cjs/schemas/crudSchema.js +9 -0
  41. package/dist/cjs/schemas/crudSchema.js.map +1 -0
  42. package/dist/cjs/schemas/index.js +18 -0
  43. package/dist/cjs/schemas/index.js.map +1 -0
  44. package/dist/cjs/services/crud.service.js +51 -0
  45. package/dist/cjs/services/crud.service.js.map +1 -0
  46. package/dist/cjs/services/crudFactory.service.js +15 -0
  47. package/dist/cjs/services/crudFactory.service.js.map +1 -0
  48. package/dist/cjs/services/cruds/dynamodb/dynamoDbClient.service.js +100 -0
  49. package/dist/cjs/services/cruds/dynamodb/dynamoDbClient.service.js.map +1 -0
  50. package/dist/cjs/services/cruds/dynamodb/dynamoDbCrud.service.js +191 -0
  51. package/dist/cjs/services/cruds/dynamodb/dynamoDbCrud.service.js.map +1 -0
  52. package/dist/cjs/services/cruds/dynamodb/queryBuilder.service.js +71 -0
  53. package/dist/cjs/services/cruds/dynamodb/queryBuilder.service.js.map +1 -0
  54. package/dist/cjs/services/cruds/dynamodb/queryBuilderCondition.service.js +144 -0
  55. package/dist/cjs/services/cruds/dynamodb/queryBuilderCondition.service.js.map +1 -0
  56. package/dist/cjs/services/cruds/index.js +19 -0
  57. package/dist/cjs/services/cruds/index.js.map +1 -0
  58. package/dist/cjs/services/cruds/postgresql/connection.service.js +40 -0
  59. package/dist/cjs/services/cruds/postgresql/connection.service.js.map +1 -0
  60. package/dist/cjs/services/cruds/postgresql/postgreSqlClient.service.js +167 -0
  61. package/dist/cjs/services/cruds/postgresql/postgreSqlClient.service.js.map +1 -0
  62. package/dist/cjs/services/cruds/postgresql/postgreSqlCrud.service.js +77 -0
  63. package/dist/cjs/services/cruds/postgresql/postgreSqlCrud.service.js.map +1 -0
  64. package/dist/cjs/services/cruds/postgresql/query.service.js +31 -0
  65. package/dist/cjs/services/cruds/postgresql/query.service.js.map +1 -0
  66. package/dist/cjs/types/connectionClosingMode.type.js +5 -0
  67. package/dist/cjs/types/connectionClosingMode.type.js.map +1 -0
  68. package/dist/cjs/types/filterInput.type.js +3 -0
  69. package/dist/cjs/types/filterInput.type.js.map +1 -0
  70. package/dist/cjs/types/filterLogicOperator.type.js +5 -0
  71. package/dist/cjs/types/filterLogicOperator.type.js.map +1 -0
  72. package/dist/cjs/types/index.js +21 -0
  73. package/dist/cjs/types/index.js.map +1 -0
  74. package/dist/cjs/types/sortDirection.type.js +5 -0
  75. package/dist/cjs/types/sortDirection.type.js.map +1 -0
  76. package/dist/cjs/utils/constants.js +68 -0
  77. package/dist/cjs/utils/constants.js.map +1 -0
  78. package/dist/esm/index.mjs +13 -0
  79. package/dist/esm/index.mjs.map +1 -0
  80. package/dist/types/index.d.ts +110 -0
  81. package/package.json +59 -0
@@ -0,0 +1,191 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.DynamoDbCrudService = void 0;
7
+ /* eslint-disable @typescript-eslint/no-explicit-any */
8
+ const q_id_generator_1 = require("q-id-generator");
9
+ const dynamoDbClient_service_1 = __importDefault(require("./dynamoDbClient.service"));
10
+ const queryBuilder_service_1 = __importDefault(require("./queryBuilder.service"));
11
+ const constants_1 = require("../../../utils/constants");
12
+ const tableHelper_1 = require("../../../helpers/tableHelper");
13
+ class DynamoDbCrudService {
14
+ constructor(tableSchema) {
15
+ this.tableSchema = tableSchema;
16
+ this.dynamoDbClientService = new dynamoDbClient_service_1.default(this.tableName);
17
+ }
18
+ get tableName() {
19
+ return (0, tableHelper_1.getTableName)(this.tableSchema.table);
20
+ }
21
+ get idColumnName() {
22
+ return (0, tableHelper_1.findIdColumnName)(this.tableSchema.columns);
23
+ }
24
+ get defaultPrimaryKeys() {
25
+ return (0, tableHelper_1.getPrimaryKeyColumns)(this.tableSchema.columns);
26
+ }
27
+ async create(entity) {
28
+ var _a;
29
+ let inputData = entity;
30
+ if (this.idColumnName) {
31
+ const idValue = ((_a = entity[this.idColumnName]) === null || _a === void 0 ? void 0 : _a.toString()) || (0, q_id_generator_1.getId)();
32
+ inputData = Object.assign(Object.assign({}, entity), { [this.idColumnName]: idValue });
33
+ }
34
+ await this.dynamoDbClientService.put(inputData);
35
+ return inputData;
36
+ }
37
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, no-unused-vars
38
+ runQuery(queryCommand) {
39
+ throw new Error('Method not implemented.');
40
+ }
41
+ async findItem(options) {
42
+ var _a;
43
+ const query = new queryBuilder_service_1.default();
44
+ this.applyFilters(query, options);
45
+ query.limit(1);
46
+ const command = query.get();
47
+ const result = await this.dynamoDbClientService.query(command);
48
+ if ((result === null || result === void 0 ? void 0 : result.Items) && ((_a = result.Items) === null || _a === void 0 ? void 0 : _a.length) > 0) {
49
+ return result.Items[0];
50
+ }
51
+ if (options.throwErrorIfNull)
52
+ throw new Error('NOT_FOUND');
53
+ return null;
54
+ }
55
+ applyWhereFilter(query, filter) {
56
+ var _a, _b;
57
+ const operator = constants_1.FILTER_OPERATOR_MAP[(_b = (_a = filter.operator) === null || _a === void 0 ? void 0 : _a.toUpperCase()) !== null && _b !== void 0 ? _b : constants_1.DYNAMODB_OPERATORS.EQUAL];
58
+ query.where(filter.attribute)[operator](filter.value);
59
+ }
60
+ applyFilterFilter(query, filter) {
61
+ var _a, _b;
62
+ const operator = constants_1.FILTER_OPERATOR_MAP[(_b = (_a = filter.operator) === null || _a === void 0 ? void 0 : _a.toUpperCase()) !== null && _b !== void 0 ? _b : constants_1.DYNAMODB_OPERATORS.EQUAL];
63
+ query.filter(filter.attribute)[operator](filter.value);
64
+ }
65
+ applyFilters(query, options) {
66
+ var _a;
67
+ if (Array.isArray(options.filters)) {
68
+ const queryIndexColumns = ((_a = options.index) === null || _a === void 0 ? void 0 : _a.columns) || [];
69
+ const defaultWhereProperties = this.defaultPrimaryKeys;
70
+ const whereProperties = (queryIndexColumns === null || queryIndexColumns === void 0 ? void 0 : queryIndexColumns.length)
71
+ ? queryIndexColumns
72
+ : defaultWhereProperties;
73
+ options.filters.forEach((filter) => {
74
+ const isWhereProperty = whereProperties.includes(filter.attribute);
75
+ isWhereProperty && !options.useScan
76
+ ? this.applyWhereFilter(query, filter)
77
+ : this.applyFilterFilter(query, filter);
78
+ });
79
+ }
80
+ }
81
+ applySorting(query, sorting, sortIndex) {
82
+ if (sorting === null || sorting === void 0 ? void 0 : sorting.length) {
83
+ if (sortIndex)
84
+ query.usingIndex(sortIndex);
85
+ if (sorting[0].direction === 'DESC') {
86
+ query.descending();
87
+ }
88
+ else {
89
+ query.ascending();
90
+ }
91
+ }
92
+ }
93
+ isNotEmptyObject(obj) {
94
+ return (obj !== null &&
95
+ typeof obj === 'object' &&
96
+ Object.keys(obj).length > 0);
97
+ }
98
+ encryptPaginationKey(key) {
99
+ const jsonKey = JSON.stringify(key);
100
+ return Buffer.from(jsonKey).toString('base64');
101
+ }
102
+ decryptPaginationKey(encodedKey) {
103
+ const decodedKey = Buffer.from(encodedKey, 'base64').toString('utf-8');
104
+ return JSON.parse(decodedKey);
105
+ }
106
+ async fetchResults(command, limit = 100, useScan = false) {
107
+ var _a, _b, _c, _d, _e;
108
+ let results = [];
109
+ let LastEvaluatedKey = {};
110
+ do {
111
+ if (this.isNotEmptyObject(LastEvaluatedKey))
112
+ command.ExclusiveStartKey = LastEvaluatedKey;
113
+ const result = await (useScan
114
+ ? this.dynamoDbClientService.scan(command)
115
+ : this.dynamoDbClientService.query(command));
116
+ command.Limit = ((_a = command.Limit) !== null && _a !== void 0 ? _a : 0) - ((_c = (_b = result.Items) === null || _b === void 0 ? void 0 : _b.length) !== null && _c !== void 0 ? _c : 0);
117
+ results = (_d = result.Items) !== null && _d !== void 0 ? _d : [];
118
+ LastEvaluatedKey = (_e = result.LastEvaluatedKey) !== null && _e !== void 0 ? _e : {};
119
+ } while (results.length < limit &&
120
+ this.isNotEmptyObject(LastEvaluatedKey));
121
+ const lastEvaluatedKey = this.isNotEmptyObject(LastEvaluatedKey)
122
+ ? this.encryptPaginationKey(LastEvaluatedKey)
123
+ : null;
124
+ return { items: results, lastEvaluatedKey };
125
+ }
126
+ applyPagination(query, pagination) {
127
+ if (pagination === null || pagination === void 0 ? void 0 : pagination.limit)
128
+ query.limit(pagination.limit);
129
+ if (pagination === null || pagination === void 0 ? void 0 : pagination.from)
130
+ query.startKey(this.decryptPaginationKey(pagination.from));
131
+ }
132
+ find(options = {}) {
133
+ var _a, _b, _c, _d;
134
+ const query = new queryBuilder_service_1.default(options.useScan);
135
+ if ((_a = options.index) === null || _a === void 0 ? void 0 : _a.indexName) {
136
+ query.usingIndex((_b = options.index) === null || _b === void 0 ? void 0 : _b.indexName);
137
+ }
138
+ this.applySorting(query, options.sorting, (_c = options.index) === null || _c === void 0 ? void 0 : _c.indexName);
139
+ this.applyPagination(query, options.pagination);
140
+ if (options.consistentRead)
141
+ query.consistentRead(options.consistentRead);
142
+ if (options.fields)
143
+ query.projection(options.fields);
144
+ this.applyFilters(query, options);
145
+ return this.fetchResults(query.get(), (_d = options.pagination) === null || _d === void 0 ? void 0 : _d.limit, options.useScan).then((res) => {
146
+ var _a, _b;
147
+ const pagination = {};
148
+ if (res.lastEvaluatedKey)
149
+ pagination.from = res.lastEvaluatedKey;
150
+ if ((_a = options.pagination) === null || _a === void 0 ? void 0 : _a.limit)
151
+ pagination.limit = (_b = options.pagination) === null || _b === void 0 ? void 0 : _b.limit;
152
+ return {
153
+ items: res.items,
154
+ pagination,
155
+ count: res.items.length,
156
+ };
157
+ });
158
+ }
159
+ async findAll(options = {}, allResults = []) {
160
+ const { items, pagination } = await this.find(options);
161
+ allResults.push(...items);
162
+ if (pagination === null || pagination === void 0 ? void 0 : pagination.from)
163
+ await this.findAll(Object.assign(Object.assign({}, options), { pagination }), allResults);
164
+ return {
165
+ items: allResults,
166
+ pagination: null,
167
+ count: allResults.length,
168
+ };
169
+ }
170
+ async update(filters, data, { replace = false }) {
171
+ const savedRecord = await this.findItem({
172
+ filters: filters,
173
+ });
174
+ if (replace) {
175
+ //delete all attributes of savedRecord except those that as marked as primary columns in the schema
176
+ }
177
+ const newData = Object.assign(Object.assign({}, savedRecord), data);
178
+ await this.dynamoDbClientService.put(newData);
179
+ return newData;
180
+ }
181
+ async remove(filters) {
182
+ const key = filters.reduce((obj, item) => {
183
+ const property = item.attribute;
184
+ obj[property] = item.value;
185
+ return obj;
186
+ }, {});
187
+ await this.dynamoDbClientService.remove(key);
188
+ }
189
+ }
190
+ exports.DynamoDbCrudService = DynamoDbCrudService;
191
+ //# sourceMappingURL=dynamoDbCrud.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dynamoDbCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAuD;AACvD,mDAAuC;AAEvC,sFAA6D;AAC7D,kFAAyD;AAEzD,wDAGkC;AASlC,8DAIsC;AAEtC,MAAa,mBAAmB;IAG5B,YAAoB,WAA8B;QAA9B,gBAAW,GAAX,WAAW,CAAmB;QAC9C,IAAI,CAAC,qBAAqB,GAAG,IAAI,gCAAqB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC3E,CAAC;IAED,IAAY,SAAS;QACjB,OAAO,IAAA,0BAAY,EAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IAAY,YAAY;QACpB,OAAO,IAAA,8BAAgB,EAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,IAAY,kBAAkB;QAC1B,OAAO,IAAA,kCAAoB,EAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAAS;;QAClB,IAAI,SAAS,GAAM,MAAM,CAAC;QAC1B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,OAAO,GACT,CAAA,MAAC,MAAc,CAAC,IAAI,CAAC,YAAY,CAAC,0CAAE,QAAQ,EAAE,KAAI,IAAA,sBAAK,GAAE,CAAC;YAC9D,SAAS,mCAAQ,MAAM,KAAE,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,OAAO,GAAE,CAAC;QAC5D,CAAC;QAED,MAAM,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAgC,CAAC,CAAC;QACvE,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,6EAA6E;IAC7E,QAAQ,CAAC,YAAiB;QACtB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,OAAqB;;QAChC,MAAM,KAAK,GAAG,IAAI,8BAAmB,EAAE,CAAC;QACxC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAClC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACf,MAAM,OAAO,GAAG,KAAK,CAAC,GAAG,EAAE,CAAC;QAC5B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC/D,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,KAAI,CAAA,MAAA,MAAM,CAAC,KAAK,0CAAE,MAAM,IAAG,CAAC,EAAE,CAAC;YAC5C,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,CAAM,CAAC;QAChC,CAAC;QACD,IAAI,OAAO,CAAC,gBAAgB;YAAE,MAAM,IAAI,KAAK,CAAC,WAAW,CAAC,CAAC;QAC3D,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,gBAAgB,CAAC,KAA0B,EAAE,MAAe;;QACxD,MAAM,QAAQ,GACV,+BAAmB,CACf,MAAA,MAAA,MAAM,CAAC,QAAQ,0CAAE,WAAW,EAAE,mCAAI,8BAAkB,CAAC,KAAK,CAC7D,CAAC;QACL,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAS,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACnE,CAAC;IAED,iBAAiB,CAAC,KAA0B,EAAE,MAAe;;QACzD,MAAM,QAAQ,GACV,+BAAmB,CACf,MAAA,MAAA,MAAM,CAAC,QAAQ,0CAAE,WAAW,EAAE,mCAAI,8BAAkB,CAAC,KAAK,CAC7D,CAAC;QACL,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAS,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACpE,CAAC;IAED,YAAY,CAAC,KAA0B,EAAE,OAAqB;;QAC1D,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACjC,MAAM,iBAAiB,GAAG,CAAA,MAAA,OAAO,CAAC,KAAK,0CAAE,OAAO,KAAI,EAAE,CAAC;YACvD,MAAM,sBAAsB,GAAG,IAAI,CAAC,kBAAkB,CAAC;YAEvD,MAAM,eAAe,GAAG,CAAA,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,MAAM;gBAC7C,CAAC,CAAC,iBAAiB;gBACnB,CAAC,CAAC,sBAAsB,CAAC;YAE7B,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC/B,MAAM,eAAe,GAAG,eAAe,CAAC,QAAQ,CAC5C,MAAM,CAAC,SAAS,CACnB,CAAC;gBACF,eAAe,IAAI,CAAC,OAAO,CAAC,OAAO;oBAC/B,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,MAAM,CAAC;oBACtC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;YAChD,CAAC,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAED,YAAY,CAAC,KAA0B,EAAE,OAAY,EAAE,SAAkB;QACrE,IAAI,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,EAAE,CAAC;YAClB,IAAI,SAAS;gBAAE,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YAC3C,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,KAAK,MAAM,EAAE,CAAC;gBAClC,KAAK,CAAC,UAAU,EAAE,CAAC;YACvB,CAAC;iBAAM,CAAC;gBACJ,KAAK,CAAC,SAAS,EAAE,CAAC;YACtB,CAAC;QACL,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,GAAY;QACzB,OAAO,CACH,GAAG,KAAK,IAAI;YACZ,OAAO,GAAG,KAAK,QAAQ;YACvB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAC9B,CAAC;IACN,CAAC;IAED,oBAAoB,CAAC,GAAwB;QACzC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QACpC,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;IAED,oBAAoB,CAAC,UAAkB;QACnC,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACvE,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IAED,KAAK,CAAC,YAAY,CACd,OAAY,EACZ,QAAgB,GAAG,EACnB,UAAmB,KAAK;;QAExB,IAAI,OAAO,GAAU,EAAE,CAAC;QACxB,IAAI,gBAAgB,GAAwB,EAAE,CAAC;QAE/C,GAAG,CAAC;YACA,IAAI,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC;gBACvC,OAAO,CAAC,iBAAiB,GAAG,gBAAgB,CAAC;YAEjD,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO;gBACzB,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC;gBAC1C,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;YAEjD,OAAO,CAAC,KAAK,GAAG,CAAC,MAAA,OAAO,CAAC,KAAK,mCAAI,CAAC,CAAC,GAAG,CAAC,MAAA,MAAA,MAAM,CAAC,KAAK,0CAAE,MAAM,mCAAI,CAAC,CAAC,CAAC;YACnE,OAAO,GAAG,MAAA,MAAM,CAAC,KAAK,mCAAI,EAAE,CAAC;YAC7B,gBAAgB,GAAG,MAAA,MAAM,CAAC,gBAAgB,mCAAI,EAAE,CAAC;QACrD,CAAC,QACG,OAAO,CAAC,MAAM,GAAG,KAAK;YACtB,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,EACzC;QAEF,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC;YAC5D,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC;YAC7C,CAAC,CAAC,IAAI,CAAC;QACX,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC;IAChD,CAAC;IAED,eAAe,CACX,KAA0B,EAC1B,UAAuC;QAEvC,IAAI,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,KAAK;YAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACrD,IAAI,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,IAAI;YAChB,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;IACnE,CAAC;IAED,IAAI,CAAC,UAAwB,EAAE;;QAC3B,MAAM,KAAK,GAAG,IAAI,8BAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAEvD,IAAI,MAAA,OAAO,CAAC,KAAK,0CAAE,SAAS,EAAE,CAAC;YAC3B,KAAK,CAAC,UAAU,CAAC,MAAA,OAAO,CAAC,KAAK,0CAAE,SAAS,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,OAAO,CAAC,OAAO,EAAE,MAAA,OAAO,CAAC,KAAK,0CAAE,SAAS,CAAC,CAAC;QACpE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;QAEhD,IAAI,OAAO,CAAC,cAAc;YACtB,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAEjD,IAAI,OAAO,CAAC,MAAM;YAAE,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAErD,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC,YAAY,CACpB,KAAK,CAAC,GAAG,EAAE,EACX,MAAA,OAAO,CAAC,UAAU,0CAAE,KAAK,EACzB,OAAO,CAAC,OAAO,CAClB,CAAC,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE;;YAChB,MAAM,UAAU,GAAoB,EAAE,CAAC;YACvC,IAAI,GAAG,CAAC,gBAAgB;gBAAE,UAAU,CAAC,IAAI,GAAG,GAAG,CAAC,gBAAgB,CAAC;YACjE,IAAI,MAAA,OAAO,CAAC,UAAU,0CAAE,KAAK;gBACzB,UAAU,CAAC,KAAK,GAAG,MAAA,OAAO,CAAC,UAAU,0CAAE,KAAK,CAAC;YACjD,OAAO;gBACH,KAAK,EAAE,GAAG,CAAC,KAAK;gBAChB,UAAU;gBACV,KAAK,EAAE,GAAG,CAAC,KAAK,CAAC,MAAM;aAC1B,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,OAAO,CACT,UAAwB,EAAE,EAC1B,aAAoB,EAAE;QAEtB,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvD,UAAU,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC;QAE1B,IAAI,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,IAAI;YAChB,MAAM,IAAI,CAAC,OAAO,iCAAM,OAAO,KAAE,UAAU,KAAI,UAAU,CAAC,CAAC;QAE/D,OAAO;YACH,KAAK,EAAE,UAAU;YACjB,UAAU,EAAE,IAAI;YAChB,KAAK,EAAE,UAAU,CAAC,MAAM;SAC3B,CAAC;IACN,CAAC;IAED,KAAK,CAAC,MAAM,CACR,OAAoC,EACpC,IAAgB,EAChB,EAAE,OAAO,GAAG,KAAK,EAAE;QAEnB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC;YACpC,OAAO,EAAE,OAAoB;SAChC,CAAC,CAAC;QAEH,IAAI,OAAO,EAAE,CAAC;YACV,mGAAmG;QACvG,CAAC;QAED,MAAM,OAAO,mCACN,WAAW,GACX,IAAI,CACV,CAAC;QAEF,MAAM,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC9C,OAAO,OAAO,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,OAAoC;QAC7C,MAAM,GAAG,GAAI,OAAqB,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,IAAS,EAAE,EAAE;YAC9D,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;YAChC,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;YAC3B,OAAO,GAAG,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;QACP,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACjD,CAAC;CACJ;AAzOD,kDAyOC"}
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const queryBuilderCondition_service_1 = __importDefault(require("./queryBuilderCondition.service"));
7
+ const queryHelpers_1 = require("../../../helpers/queryHelpers");
8
+ class QueryBuilderService {
9
+ constructor(useScan = false) {
10
+ this.useScan = useScan;
11
+ this.command = {};
12
+ this.condition = new queryBuilderCondition_service_1.default(this);
13
+ }
14
+ get() {
15
+ const condition = this.condition.get();
16
+ return Object.assign(Object.assign({}, this.command), condition);
17
+ }
18
+ limit(num) {
19
+ this.command.Limit = num;
20
+ return this;
21
+ }
22
+ usingIndex(indexName) {
23
+ this.command.IndexName = indexName;
24
+ return this;
25
+ }
26
+ ascending() {
27
+ if (!this.useScan)
28
+ this.command.ScanIndexForward = true;
29
+ return this;
30
+ }
31
+ descending() {
32
+ if (!this.useScan)
33
+ this.command.ScanIndexForward = false;
34
+ return this;
35
+ }
36
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
37
+ startKey(lastEvaluatedKey) {
38
+ this.command.ExclusiveStartKey = lastEvaluatedKey;
39
+ return this;
40
+ }
41
+ projection(fields) {
42
+ const expression = [];
43
+ fields.forEach((field) => {
44
+ const key = this.condition.project(field);
45
+ expression.push(key);
46
+ });
47
+ this.command.ProjectionExpression = expression.join(',');
48
+ return this;
49
+ }
50
+ where(keyName) {
51
+ this.condition.setKey(keyName).from(queryHelpers_1.METHOD_TO_QUERY.where);
52
+ return this.condition;
53
+ }
54
+ filter(keyName) {
55
+ this.condition.setKey(keyName).from(queryHelpers_1.METHOD_TO_QUERY.filter);
56
+ return this.condition;
57
+ }
58
+ update(attribute) {
59
+ for (const [key, value] of Object.entries(attribute)) {
60
+ this.condition.setKey(key).from(queryHelpers_1.METHOD_TO_QUERY.update);
61
+ this.condition.eq(value);
62
+ }
63
+ return this;
64
+ }
65
+ consistentRead(consistentRead) {
66
+ this.command.ConsistentRead = consistentRead;
67
+ return this;
68
+ }
69
+ }
70
+ exports.default = QueryBuilderService;
71
+ //# sourceMappingURL=queryBuilder.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"queryBuilder.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/dynamodb/queryBuilder.service.ts"],"names":[],"mappings":";;;;;AAEA,oGAA2E;AAC3E,gEAAgE;AAGhE,MAAqB,mBAAmB;IAIpC,YAAoB,UAAU,KAAK;QAAf,YAAO,GAAP,OAAO,CAAQ;QAC/B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAElB,IAAI,CAAC,SAAS,GAAG,IAAI,uCAA4B,CAAC,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED,GAAG;QACC,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;QACvC,uCAAY,IAAI,CAAC,OAAO,GAAK,SAAS,EAAG;IAC7C,CAAC;IAED,KAAK,CAAC,GAAW;QACb,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,GAAG,CAAC;QACzB,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,UAAU,CAAC,SAAiB;QACxB,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;QACnC,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,SAAS;QACL,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC;QACxD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,UAAU;QACN,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,GAAG,KAAK,CAAC;QACzD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,8DAA8D;IAC9D,QAAQ,CAAC,gBAAqC;QAC1C,IAAI,CAAC,OAAO,CAAC,iBAAiB,GAAG,gBAAgB,CAAC;QAClD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,UAAU,CAAC,MAAgB;QACvB,MAAM,UAAU,GAAa,EAAE,CAAC;QAChC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACrB,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAC1C,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACzB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,oBAAoB,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACzD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,OAAe;QACjB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,8BAAe,CAAC,KAAK,CAAC,CAAC;QAC3D,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,OAAe;QAClB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,8BAAe,CAAC,MAAM,CAAC,CAAC;QAC5D,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,SAAiC;QACpC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YACnD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,8BAAe,CAAC,MAAM,CAAC,CAAC;YACxD,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,cAAc,CAAC,cAAuB;QAClC,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,cAAc,CAAC;QAC7C,OAAO,IAAI,CAAC;IAChB,CAAC;CACJ;AAzED,sCAyEC"}
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const queryHelpers_1 = require("../../../helpers/queryHelpers");
4
+ class QueryBuilderConditionService {
5
+ constructor(query) {
6
+ this.tempKey = '';
7
+ this.wheres = [];
8
+ this.filters = [];
9
+ this.updates = [];
10
+ this.attributeNames = {};
11
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
12
+ this.attributeValues = {};
13
+ this.query = query;
14
+ this.command = {};
15
+ }
16
+ get() {
17
+ this.build();
18
+ return this.command;
19
+ }
20
+ setKey(key) {
21
+ this.tempKey = key;
22
+ return this;
23
+ }
24
+ from(methodName) {
25
+ this.queryFrom = methodName;
26
+ return this;
27
+ }
28
+ eq(keyValue) {
29
+ const { key, value } = this.generateKeyValue(keyValue);
30
+ const expression = `${key} = ${value}`;
31
+ this.setExpression(expression);
32
+ return this.query;
33
+ }
34
+ notEq(keyValue) {
35
+ const { key, value } = this.generateKeyValue(keyValue);
36
+ const expression = `${key} <> ${value}`;
37
+ this.setExpression(expression);
38
+ return this.query;
39
+ }
40
+ contains(keyValue) {
41
+ const { key, value } = this.generateKeyValue(keyValue);
42
+ const expression = `contains(${key}, ${value})`;
43
+ this.setExpression(expression);
44
+ return this.query;
45
+ }
46
+ notContains(keyValue) {
47
+ const { key, value } = this.generateKeyValue(keyValue);
48
+ const expression = `NOT contains(${key}, ${value})`;
49
+ this.setExpression(expression);
50
+ return this.query;
51
+ }
52
+ in(keyValue) {
53
+ const keyValues = Array.isArray(keyValue) ? keyValue : [keyValue];
54
+ const { key, value } = this.generateKeyValue(keyValues);
55
+ const expression = `${key} IN (${value})`;
56
+ this.setExpression(expression);
57
+ return this.query;
58
+ }
59
+ beginsWith(keyValue) {
60
+ const { key, value } = this.generateKeyValue(keyValue);
61
+ const expression = `begins_with(${key}, ${value})`;
62
+ this.setExpression(expression);
63
+ return this.query;
64
+ }
65
+ project(keyValue) {
66
+ const key = `#${keyValue}`;
67
+ this.attributeNames[key] = keyValue;
68
+ return key;
69
+ }
70
+ gt(keyValue) {
71
+ const { key, value } = this.generateKeyValue(keyValue);
72
+ const expression = `${key} > ${value}`;
73
+ this.setExpression(expression);
74
+ return this.query;
75
+ }
76
+ gte(keyValue) {
77
+ const { key, value } = this.generateKeyValue(keyValue);
78
+ const expression = `${key} >= ${value}`;
79
+ this.setExpression(expression);
80
+ return this.query;
81
+ }
82
+ lte(keyValue) {
83
+ const { key, value } = this.generateKeyValue(keyValue);
84
+ const expression = `${key} <= ${value}`;
85
+ this.setExpression(expression);
86
+ return this.query;
87
+ }
88
+ lt(keyValue) {
89
+ const { key, value } = this.generateKeyValue(keyValue);
90
+ const expression = `${key} < ${value}`;
91
+ this.setExpression(expression);
92
+ return this.query;
93
+ }
94
+ setExpression(expression) {
95
+ switch (this.queryFrom) {
96
+ case queryHelpers_1.METHOD_TO_QUERY.filter:
97
+ this.filters.push(expression);
98
+ break;
99
+ case queryHelpers_1.METHOD_TO_QUERY.update:
100
+ this.updates.push(expression);
101
+ break;
102
+ default:
103
+ this.wheres.push(expression);
104
+ break;
105
+ }
106
+ }
107
+ generateKeyValue(value) {
108
+ const keyExpression = `#${this.tempKey}1`;
109
+ this.attributeNames[keyExpression] = this.tempKey;
110
+ if (Array.isArray(value)) {
111
+ const valueExpressions = value.map((val, index) => {
112
+ const valueExpression = `:${this.tempKey}${index + 1}1`;
113
+ this.attributeValues[valueExpression] = val;
114
+ return valueExpression;
115
+ });
116
+ return { key: keyExpression, value: valueExpressions.join(', ') };
117
+ }
118
+ else {
119
+ const valueExpression = `:${this.tempKey}1`;
120
+ this.attributeValues[valueExpression] = value;
121
+ return { key: keyExpression, value: valueExpression };
122
+ }
123
+ }
124
+ build() {
125
+ if (this.wheres.length > 0) {
126
+ const keyConditionExpression = this.wheres.join(' AND ');
127
+ this.command['KeyConditionExpression'] = keyConditionExpression;
128
+ }
129
+ if (this.filters.length > 0) {
130
+ const filterExpression = this.filters.join(' AND ');
131
+ this.command['FilterExpression'] = filterExpression;
132
+ }
133
+ if (this.updates.length > 0) {
134
+ const filterExpression = this.updates.join(', ');
135
+ this.command['UpdateExpression'] = `SET ${filterExpression}`;
136
+ }
137
+ if (Object.values(this.attributeNames).length > 0)
138
+ this.command['ExpressionAttributeNames'] = this.attributeNames;
139
+ if (Object.values(this.attributeValues).length > 0)
140
+ this.command['ExpressionAttributeValues'] = this.attributeValues;
141
+ }
142
+ }
143
+ exports.default = QueryBuilderConditionService;
144
+ //# sourceMappingURL=queryBuilderCondition.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"queryBuilderCondition.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/dynamodb/queryBuilderCondition.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
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
+ __exportStar(require("./dynamodb/dynamoDbCrud.service"), exports);
18
+ __exportStar(require("./postgresql/postgreSqlCrud.service"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/services/cruds/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kEAAgD;AAChD,sEAAoD"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const pg_1 = require("pg");
4
+ class ConnectionService {
5
+ constructor(usePool) {
6
+ this.pool = null;
7
+ if (usePool)
8
+ this.pool = new pg_1.Pool({ connectionString: this.connectionString });
9
+ }
10
+ get connectionString() {
11
+ return process.env.PG_CONNECTION_STRING;
12
+ }
13
+ async getClient() {
14
+ if (this.pool) {
15
+ return this.pool.connect();
16
+ }
17
+ else {
18
+ const client = new pg_1.Client({
19
+ connectionString: this.connectionString,
20
+ });
21
+ await client.connect();
22
+ return client;
23
+ }
24
+ }
25
+ releaseClient(client) {
26
+ try {
27
+ if ('release' in client) {
28
+ client.release();
29
+ }
30
+ else if ('end' in client) {
31
+ client.end();
32
+ }
33
+ }
34
+ catch (_a) {
35
+ // ignore any exception
36
+ }
37
+ }
38
+ }
39
+ exports.default = ConnectionService;
40
+ //# sourceMappingURL=connection.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/connection.service.ts"],"names":[],"mappings":";;AAAA,2BAA8C;AAE9C,MAAqB,iBAAiB;IAGlC,YAAY,OAAgB;QAFpB,SAAI,GAAgB,IAAI,CAAC;QAG7B,IAAI,OAAO;YACP,IAAI,CAAC,IAAI,GAAG,IAAI,SAAI,CAAC,EAAE,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC1E,CAAC;IAED,IAAI,gBAAgB;QAChB,OAAO,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,SAAS;QACX,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACZ,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;QAC/B,CAAC;aAAM,CAAC;YACJ,MAAM,MAAM,GAAW,IAAI,WAAM,CAAC;gBAC9B,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;aAC1C,CAAC,CAAC;YACH,MAAM,MAAM,CAAC,OAAO,EAAE,CAAC;YACvB,OAAO,MAAM,CAAC;QAClB,CAAC;IACL,CAAC;IAED,aAAa,CAAC,MAA2B;QACrC,IAAI,CAAC;YACD,IAAI,SAAS,IAAI,MAAM,EAAE,CAAC;gBACtB,MAAM,CAAC,OAAO,EAAE,CAAC;YACrB,CAAC;iBAAM,IAAI,KAAK,IAAI,MAAM,EAAE,CAAC;gBACzB,MAAM,CAAC,GAAG,EAAE,CAAC;YACjB,CAAC;QACL,CAAC;QAAC,WAAM,CAAC;YACL,uBAAuB;QAC3B,CAAC;IACL,CAAC;CACJ;AAnCD,oCAmCC"}