@skillswaveca/nova-shared-libraries 4.18.0 → 4.18.2

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.
@@ -1,31 +1,31 @@
1
1
  export const packageInfo = [
2
2
  {
3
3
  "name": "@skillswaveca/nova-utils",
4
- "version": "4.17.1",
4
+ "version": "4.18.1",
5
5
  "description": "A collection of random utils used in nova repos",
6
6
  "docsPath": "./nova-utils/index.html"
7
7
  },
8
8
  {
9
9
  "name": "@skillswaveca/nova-router",
10
- "version": "4.17.1",
10
+ "version": "4.18.1",
11
11
  "description": "An extended Koa router that enables better validation",
12
12
  "docsPath": "./nova-router/index.html"
13
13
  },
14
14
  {
15
15
  "name": "@skillswaveca/nova-model",
16
- "version": "4.17.1",
16
+ "version": "4.18.1",
17
17
  "description": "Nova model stuff",
18
18
  "docsPath": "./nova-model/index.html"
19
19
  },
20
20
  {
21
21
  "name": "@skillswaveca/nova-middleware",
22
- "version": "4.17.1",
22
+ "version": "4.18.1",
23
23
  "description": "A collection of middleware used by nova projects",
24
24
  "docsPath": "./nova-middleware/index.html"
25
25
  },
26
26
  {
27
27
  "name": "@skillswaveca/nova-drivers",
28
- "version": "4.17.1",
28
+ "version": "4.18.1",
29
29
  "description": "Some helper drivers for AWS services",
30
30
  "docsPath": "./drivers/index.html"
31
31
  }
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "name": "@skillswaveca/nova-shared-libraries",
4
4
  "description": "A monorepo of shared libraries for Nova projects.",
5
5
  "repository": "https://github.com/SkillsWave/nova-shared-libraries",
6
- "version": "4.18.0",
6
+ "version": "4.18.2",
7
7
  "main": "index.js",
8
8
  "license": "MIT",
9
9
  "keywords": [],
@@ -3,7 +3,7 @@
3
3
  "name": "@skillswaveca/nova-drivers",
4
4
  "description": "Some helper drivers for AWS services",
5
5
  "repository": "https://github.com/SkillsWave/nova-shared-libraries",
6
- "version": "4.18.0",
6
+ "version": "4.18.2",
7
7
  "main": "index.js",
8
8
  "scripts": {
9
9
  "pre-release": "pnpm run create-index",
@@ -3,7 +3,7 @@
3
3
  "name": "@skillswaveca/nova-middleware",
4
4
  "description": "A collection of middleware used by nova projects",
5
5
  "repository": "https://github.com/SkillsWave/nova-shared-libraries",
6
- "version": "4.18.0",
6
+ "version": "4.18.2",
7
7
  "main": "index.js",
8
8
  "scripts": {
9
9
  "pre-release": "pnpm run create-index",
@@ -3,7 +3,7 @@
3
3
  "name": "@skillswaveca/nova-model",
4
4
  "description": "Nova model stuff",
5
5
  "repository": "https://github.com/SkillsWave/nova-shared-libraries",
6
- "version": "4.18.0",
6
+ "version": "4.18.2",
7
7
  "main": "index.js",
8
8
  "scripts": {
9
9
  "pre-release": "pnpm run create-index",
@@ -162,55 +162,15 @@ export class NovaModelRepo {
162
162
  return undefined;
163
163
  }
164
164
 
165
- // This recursive code handles paged data in query results
166
- async getAllResultsRecursive(context, params, results, limit, level = 0, startTime = 0, startingParams) {
167
- if (level === 0) {
168
- startTime = Date.now();
169
- startingParams = Object.assign({}, params);
170
- }
171
- level++;
172
-
173
- if (limit) {
174
- params.Limit = limit - results.length;
175
- }
176
-
177
- const data = await this.query(context, params);
178
-
179
- if (data?.Items?.length > 0) {
180
- results.push(...data.Items);
181
- }
182
-
183
- if (data.LastEvaluatedKey) {
184
- params.ExclusiveStartKey = data.LastEvaluatedKey;
185
- } else if (params.ExclusiveStartKey) {
186
- delete params.ExclusiveStartKey;
187
- }
188
-
189
- if (data.LastEvaluatedKey && (!limit || results.length < limit)) {
190
- return await this.getAllResultsRecursive(context, params, results, limit, level, startTime, startingParams);
191
- } else {
192
- const endTime = Date.now();
193
- const timeTaken = endTime - startTime;
194
- if ((level >= DDB_WARN_RECURSION_LEVELS) || (timeTaken >= DDB_WARN_TIME)) {
195
- context.log.warn({ startingParams, timeTaken, recursionLevel: level }, `getAllResultsRecursive: ${level} ${(level === 1) ? 'query' : 'queries'} for startingParams; took ${timeTaken} ms`);
196
- }
197
-
198
- return limit ? results.slice(0, limit) : results;
199
- }
200
- }
201
-
202
165
  /**
203
166
  * This function returns the array of recursively retrieved results based
204
167
  * on a DynamoDB query with the given parameters. It uses the
205
168
  * getAllResultsRecursive function and returns all pages of results.
206
- * @param {Object} context
207
169
  * @param {Object} params - DynamoDB query params
208
170
  * @returns {Array<*>} recursively retrieved results from dynamoDb query
209
171
  */
210
- async getAllResults(context, params) {
211
- const results = [];
212
- await this.getAllResultsRecursive(context, params, results);
213
- return results?.Items || results;
172
+ async getAllResults(params) {
173
+ return await this.dynamodb.getAllResults(params);
214
174
  }
215
175
 
216
176
  /**
@@ -26,12 +26,12 @@ export class NovaStreamTaskRouter {
26
26
  handle(newRecord, oldRecord) {
27
27
  const { recordType, operation } = this.getRecordStatus(oldRecord, newRecord);
28
28
  if (!recordType) {
29
- log.debug({ recordType, operation }, 'No record type found');
29
+ log.trace({ recordType, operation }, 'No record type found');
30
30
  return null;
31
31
  }
32
32
  const handler = this._recordHandlers[recordType]?.[operation];
33
33
  if (!handler) {
34
- log.debug({ recordType, operation }, 'No handler found for record');
34
+ log.trace({ recordType, operation }, 'No handler found for record');
35
35
  return null;
36
36
  }
37
37
  return handler(newRecord, oldRecord);
@@ -3,13 +3,12 @@
3
3
  "name": "@skillswaveca/nova-router",
4
4
  "description": "An extended Koa router that enables better validation",
5
5
  "repository": "https://github.com/SkillsWave/nova-shared-libraries",
6
- "version": "4.18.0",
6
+ "version": "4.18.2",
7
7
  "main": "index.js",
8
8
  "scripts": {
9
9
  "pre-release": "pnpm run create-index",
10
10
  "create-index": "node ../../scripts/create-index.js",
11
- "generate-docs": "documentation build src/** -f html -o docs",
12
- "test": "mocha --parallel 'test/**/*.test.js'"
11
+ "generate-docs": "documentation build src/** -f html -o docs"
13
12
  },
14
13
  "author": "SkillsWave",
15
14
  "license": "UNLICENSED",
@@ -3,7 +3,7 @@
3
3
  "name": "@skillswaveca/nova-utils",
4
4
  "description": "A collection of random utils used in nova repos",
5
5
  "repository": "https://github.com/SkillsWave/nova-shared-libraries",
6
- "version": "4.18.0",
6
+ "version": "4.18.2",
7
7
  "main": "index.js",
8
8
  "scripts": {
9
9
  "pre-release": "pnpm run create-index",
@@ -14,7 +14,7 @@ export const asyncContext = new AsyncLocalStorage();
14
14
  * @type {pino.Logger}
15
15
  */
16
16
  const baseLogger = pino({
17
- level: process.env.NODE_ENV === 'production' ? 'info' : 'debug',
17
+ level: 'info',
18
18
  });
19
19
 
20
20
  /**