quidproquo-actionprocessor-awslambda 0.0.115 → 0.0.117

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.
@@ -15,14 +15,14 @@ const quidproquo_core_2 = require("quidproquo-core");
15
15
  const dynamo_1 = require("../../../logic/dynamo");
16
16
  const qpqDynamoOrm_1 = require("../../../logic/dynamo/qpqDynamoOrm");
17
17
  const getProcessKeyValueStoreQuery = (qpqConfig) => {
18
- return ({ keyValueStoreName, keyCondition, filterCondition }) => __awaiter(void 0, void 0, void 0, function* () {
18
+ return ({ keyValueStoreName, keyCondition, filterCondition, nextPageKey }) => __awaiter(void 0, void 0, void 0, function* () {
19
19
  const dynamoTableName = (0, awsNamingUtils_1.getKvsDynamoTableNameFromConfig)(keyValueStoreName, qpqConfig, 'kvs');
20
20
  const region = quidproquo_core_1.qpqCoreUtils.getApplicationModuleDeployRegion(qpqConfig);
21
21
  const storeConfig = quidproquo_core_1.qpqCoreUtils.getKeyValueStoreByName(qpqConfig, keyValueStoreName);
22
22
  if (!storeConfig) {
23
23
  return (0, quidproquo_core_1.actionResultError)(quidproquo_core_1.ErrorTypeEnum.NotFound, `Could not find key value store with name "${keyValueStoreName}"`);
24
24
  }
25
- const items = yield (0, dynamo_1.query)(dynamoTableName, region, keyCondition, filterCondition, (0, qpqDynamoOrm_1.getDynamoTableIndexByConfigAndQuery)(storeConfig, keyCondition));
25
+ const items = yield (0, dynamo_1.query)(dynamoTableName, region, keyCondition, filterCondition, nextPageKey, (0, qpqDynamoOrm_1.getDynamoTableIndexByConfigAndQuery)(storeConfig, keyCondition));
26
26
  return (0, quidproquo_core_2.actionResult)(items);
27
27
  });
28
28
  };
@@ -14,10 +14,10 @@ const awsNamingUtils_1 = require("../../../awsNamingUtils");
14
14
  const quidproquo_core_2 = require("quidproquo-core");
15
15
  const scan_1 = require("../../../logic/dynamo/scan");
16
16
  const getProcessKeyValueStoreScan = (qpqConfig) => {
17
- return ({ keyValueStoreName, filterCondition }) => __awaiter(void 0, void 0, void 0, function* () {
17
+ return ({ keyValueStoreName, filterCondition, nextPageKey }) => __awaiter(void 0, void 0, void 0, function* () {
18
18
  const dynamoTableName = (0, awsNamingUtils_1.getKvsDynamoTableNameFromConfig)(keyValueStoreName, qpqConfig, 'kvs');
19
19
  const region = quidproquo_core_1.qpqCoreUtils.getApplicationModuleDeployRegion(qpqConfig);
20
- const items = yield (0, scan_1.scan)(dynamoTableName, region, filterCondition);
20
+ const items = yield (0, scan_1.scan)(dynamoTableName, region, filterCondition, nextPageKey);
21
21
  return (0, quidproquo_core_2.actionResult)(items);
22
22
  });
23
23
  };
@@ -0,0 +1,5 @@
1
+ import { UserDirectoryGetUserAttributesByUserIdActionProcessor, QPQConfig } from 'quidproquo-core';
2
+ declare const _default: (qpqConfig: QPQConfig) => {
3
+ "@quidproquo-core/UserDirectory/GetUserAttributesByUserId": UserDirectoryGetUserAttributesByUserIdActionProcessor;
4
+ };
5
+ export default _default;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const quidproquo_core_1 = require("quidproquo-core");
13
+ const awsNamingUtils_1 = require("../../../awsNamingUtils");
14
+ const getExportedValue_1 = require("../../../logic/cloudformation/getExportedValue");
15
+ const getUserAttributesBySub_1 = require("../../../logic/cognito/getUserAttributesBySub");
16
+ const getUserDirectoryGetUserAttributesByUserIdActionProcessor = (qpqConfig) => {
17
+ return ({ userDirectoryName, serviceOverride, userId }, session) => __awaiter(void 0, void 0, void 0, function* () {
18
+ const region = quidproquo_core_1.qpqCoreUtils.getApplicationModuleDeployRegion(qpqConfig);
19
+ const userPoolId = yield (0, getExportedValue_1.getExportedValue)((0, awsNamingUtils_1.getCFExportNameUserPoolIdFromConfig)(userDirectoryName, qpqConfig, serviceOverride), region);
20
+ const userAttributes = yield (0, getUserAttributesBySub_1.getUserAttributesBySub)(userPoolId, region, userId);
21
+ return (0, quidproquo_core_1.actionResult)(userAttributes);
22
+ });
23
+ };
24
+ exports.default = (qpqConfig) => {
25
+ return {
26
+ [quidproquo_core_1.UserDirectoryActionType.GetUserAttributesByUserId]: getUserDirectoryGetUserAttributesByUserIdActionProcessor(qpqConfig),
27
+ };
28
+ };
@@ -5,6 +5,7 @@ declare const _default: (qpqConfig: QPQConfig) => {
5
5
  "@quidproquo-core/UserDirectory/RequestEmailVerification": import("quidproquo-core").UserDirectoryRequestEmailVerificationActionProcessor;
6
6
  "@quidproquo-core/UserDirectory/RefreshToken": import("quidproquo-core").UserDirectoryRefreshTokenActionProcessor;
7
7
  "@quidproquo-core/UserDirectory/ReadAccessToken": import("quidproquo-core").UserDirectoryReadAccessTokenActionProcessor;
8
+ "@quidproquo-core/UserDirectory/GetUserAttributesByUserId": import("quidproquo-core").UserDirectoryGetUserAttributesByUserIdActionProcessor;
8
9
  "@quidproquo-core/UserDirectory/GetUserAttributes": import("quidproquo-core").UserDirectoryGetUserAttributesActionProcessor;
9
10
  "@quidproquo-core/UserDirectory/ForgotPassword": import("quidproquo-core").UserDirectoryForgotPasswordActionProcessor;
10
11
  "@quidproquo-core/UserDirectory/DecodeAccessToken": import("quidproquo-core").UserDirectoryDecodeAccessTokenActionProcessor;
@@ -10,9 +10,10 @@ const getUserDirectoryCreateUserActionProcessor_1 = __importDefault(require("./g
10
10
  const getUserDirectoryDecodeAccessTokenActionProcessor_1 = __importDefault(require("./getUserDirectoryDecodeAccessTokenActionProcessor"));
11
11
  const getUserDirectoryForgetPasswordActionProcessor_1 = __importDefault(require("./getUserDirectoryForgetPasswordActionProcessor"));
12
12
  const getUserDirectoryGetUserAttributesActionProcessor_1 = __importDefault(require("./getUserDirectoryGetUserAttributesActionProcessor"));
13
+ const getUserDirectoryGetUserAttributesByUserIdActionProcessor_1 = __importDefault(require("./getUserDirectoryGetUserAttributesByUserIdActionProcessor"));
13
14
  const getUserDirectoryReadAccessTokenActionProcessor_1 = __importDefault(require("./getUserDirectoryReadAccessTokenActionProcessor"));
14
15
  const getUserDirectoryRefreshTokenActionProcessor_1 = __importDefault(require("./getUserDirectoryRefreshTokenActionProcessor"));
15
16
  const getUserDirectoryRequestEmailVerificationActionProcessor_1 = __importDefault(require("./getUserDirectoryRequestEmailVerificationActionProcessor"));
16
17
  const getUserDirectoryRespondToAuthChallengeActionProcessor_1 = __importDefault(require("./getUserDirectoryRespondToAuthChallengeActionProcessor"));
17
18
  const getUserDirectorySetUserAttributesActionProcessor_1 = __importDefault(require("./getUserDirectorySetUserAttributesActionProcessor"));
18
- exports.default = (qpqConfig) => (Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, (0, getUserDirectoryAuthenticateUserActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryConfirmEmailVerificationActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryConfirmForgetPasswordActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryCreateUserActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryDecodeAccessTokenActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryForgetPasswordActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryGetUserAttributesActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryReadAccessTokenActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryRefreshTokenActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryRequestEmailVerificationActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryRespondToAuthChallengeActionProcessor_1.default)(qpqConfig)), (0, getUserDirectorySetUserAttributesActionProcessor_1.default)(qpqConfig)));
19
+ exports.default = (qpqConfig) => (Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, (0, getUserDirectoryAuthenticateUserActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryConfirmEmailVerificationActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryConfirmForgetPasswordActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryCreateUserActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryDecodeAccessTokenActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryForgetPasswordActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryGetUserAttributesActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryGetUserAttributesByUserIdActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryReadAccessTokenActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryRefreshTokenActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryRequestEmailVerificationActionProcessor_1.default)(qpqConfig)), (0, getUserDirectoryRespondToAuthChallengeActionProcessor_1.default)(qpqConfig)), (0, getUserDirectorySetUserAttributesActionProcessor_1.default)(qpqConfig)));
@@ -0,0 +1,2 @@
1
+ import { UserAttributes } from 'quidproquo-core';
2
+ export declare const getUserAttributesBySub: (userPoolId: string, region: string, sub: string) => Promise<UserAttributes>;
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.getUserAttributesBySub = void 0;
13
+ const client_cognito_identity_provider_1 = require("@aws-sdk/client-cognito-identity-provider");
14
+ const cognitoAttributeMap_1 = require("./cognitoAttributeMap");
15
+ const getUserAttributesBySub = (userPoolId, region, sub) => __awaiter(void 0, void 0, void 0, function* () {
16
+ const cognitoClient = new client_cognito_identity_provider_1.CognitoIdentityProviderClient({ region });
17
+ const response = yield cognitoClient.send(new client_cognito_identity_provider_1.ListUsersCommand({
18
+ UserPoolId: userPoolId,
19
+ Filter: `sub = "${sub}"`,
20
+ }));
21
+ console.log(response);
22
+ const [user] = (response === null || response === void 0 ? void 0 : response.Users) || [];
23
+ if (!user) {
24
+ throw new Error('User not found');
25
+ }
26
+ const validAttributes = (user.Attributes || []).filter((attr) => attr.Name && attr.Value);
27
+ return (0, cognitoAttributeMap_1.getQpqAttributesFromCognitoUserAttributes)(validAttributes);
28
+ });
29
+ exports.getUserAttributesBySub = getUserAttributesBySub;
@@ -1 +1,2 @@
1
- export declare function stringToLastEvaluatedKey(encodedKey: string): any;
1
+ import { AttributeValue } from '@aws-sdk/client-dynamodb';
2
+ export declare function stringToLastEvaluatedKey(encodedKey: string): Record<string, AttributeValue>;
@@ -1,2 +1,2 @@
1
- import { KvsQueryOperation } from 'quidproquo-core';
2
- export declare function query<Item>(tableName: string, region: string, keyExpression: KvsQueryOperation, filterExpression?: KvsQueryOperation, indexName?: string): Promise<Item[]>;
1
+ import { KvsQueryOperation, QpqPagedData } from 'quidproquo-core';
2
+ export declare function query<Item>(tableName: string, region: string, keyExpression: KvsQueryOperation, filterExpression?: KvsQueryOperation, pageKey?: string, indexName?: string): Promise<QpqPagedData<Item>>;
@@ -12,8 +12,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.query = void 0;
13
13
  const client_dynamodb_1 = require("@aws-sdk/client-dynamodb");
14
14
  const convertObjectToDynamoMap_1 = require("./convertObjectToDynamoMap");
15
+ const logs_1 = require("./logs");
16
+ const itemsToQpqPagedData_1 = require("./utils/itemsToQpqPagedData");
15
17
  const qpqDynamoOrm_1 = require("./qpqDynamoOrm");
16
- function query(tableName, region, keyExpression, filterExpression, indexName) {
18
+ function query(tableName, region, keyExpression, filterExpression, pageKey, indexName) {
17
19
  var _a;
18
20
  return __awaiter(this, void 0, void 0, function* () {
19
21
  // Instantiate DynamoDB client
@@ -26,13 +28,14 @@ function query(tableName, region, keyExpression, filterExpression, indexName) {
26
28
  ExpressionAttributeNames: (0, qpqDynamoOrm_1.buildExpressionAttributeNames)([keyExpression, filterExpression]),
27
29
  IndexName: indexName,
28
30
  };
29
- // TODO: Remove this log
30
- console.log(params);
31
+ if (pageKey) {
32
+ params.ExclusiveStartKey = (0, logs_1.stringToLastEvaluatedKey)(pageKey);
33
+ }
31
34
  // Create QueryCommand
32
35
  const command = new client_dynamodb_1.QueryCommand(params);
33
36
  // TODO: Catch errors and throw QPQ ones
34
37
  const data = yield dynamoClient.send(command);
35
- return (((_a = data.Items) === null || _a === void 0 ? void 0 : _a.map((i) => (0, convertObjectToDynamoMap_1.convertDynamoMapToObject)(i))) || []);
38
+ return (0, itemsToQpqPagedData_1.itemsToQpqPagedData)((((_a = data.Items) === null || _a === void 0 ? void 0 : _a.map((i) => (0, convertObjectToDynamoMap_1.convertDynamoMapToObject)(i))) || []), data.LastEvaluatedKey);
36
39
  });
37
40
  }
38
41
  exports.query = query;
@@ -1,2 +1,2 @@
1
- import { KvsQueryOperation } from 'quidproquo-core';
2
- export declare function scan<Item>(tableName: string, region: string, filterExpression?: KvsQueryOperation): Promise<Item[]>;
1
+ import { KvsQueryOperation, QpqPagedData } from 'quidproquo-core';
2
+ export declare function scan<Item>(tableName: string, region: string, filterExpression?: KvsQueryOperation, pageKey?: string): Promise<QpqPagedData<Item>>;
@@ -12,8 +12,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.scan = void 0;
13
13
  const client_dynamodb_1 = require("@aws-sdk/client-dynamodb");
14
14
  const convertObjectToDynamoMap_1 = require("./convertObjectToDynamoMap");
15
+ const logs_1 = require("./logs");
16
+ const itemsToQpqPagedData_1 = require("./utils/itemsToQpqPagedData");
15
17
  const qpqDynamoOrm_1 = require("./qpqDynamoOrm");
16
- function scan(tableName, region, filterExpression) {
18
+ function scan(tableName, region, filterExpression, pageKey) {
17
19
  var _a;
18
20
  return __awaiter(this, void 0, void 0, function* () {
19
21
  // Instantiate DynamoDB client
@@ -24,12 +26,14 @@ function scan(tableName, region, filterExpression) {
24
26
  ExpressionAttributeValues: (0, qpqDynamoOrm_1.buildExpressionAttributeValues)([filterExpression]),
25
27
  ExpressionAttributeNames: (0, qpqDynamoOrm_1.buildExpressionAttributeNames)([filterExpression]),
26
28
  };
27
- console.log(params);
29
+ if (pageKey) {
30
+ params.ExclusiveStartKey = (0, logs_1.stringToLastEvaluatedKey)(pageKey);
31
+ }
28
32
  // Create ScanCommand
29
33
  const command = new client_dynamodb_1.ScanCommand(params);
30
34
  // TODO: Catch errors and throw QPQ ones
31
35
  const data = yield dynamoClient.send(command);
32
- return (((_a = data.Items) === null || _a === void 0 ? void 0 : _a.map((i) => (0, convertObjectToDynamoMap_1.convertDynamoMapToObject)(i))) || []);
36
+ return (0, itemsToQpqPagedData_1.itemsToQpqPagedData)((((_a = data.Items) === null || _a === void 0 ? void 0 : _a.map((i) => (0, convertObjectToDynamoMap_1.convertDynamoMapToObject)(i))) || []), data.LastEvaluatedKey);
33
37
  });
34
38
  }
35
39
  exports.scan = scan;
@@ -0,0 +1,2 @@
1
+ import { QpqPagedData } from 'quidproquo-core';
2
+ export declare const itemsToQpqPagedData: <T>(items: T[], lastEvaluatedKey?: any) => QpqPagedData<T>;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.itemsToQpqPagedData = void 0;
4
+ const logs_1 = require("../logs");
5
+ const itemsToQpqPagedData = (items, lastEvaluatedKey) => ({
6
+ items,
7
+ nextPageKey: lastEvaluatedKey ? (0, logs_1.lastEvaluatedKeyToString)(lastEvaluatedKey) : undefined,
8
+ });
9
+ exports.itemsToQpqPagedData = itemsToQpqPagedData;
@@ -0,0 +1,4 @@
1
+ export declare const itemsToQpqPagedData: <T>(items: T[], lastEvaluatedKey?: string) => {
2
+ items: T[];
3
+ lastEvaluatedKey: "" | Record<string, import("@aws-sdk/client-dynamodb").AttributeValue> | undefined;
4
+ };
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.itemsToQpqPagedData = void 0;
4
+ const logs_1 = require("../logs");
5
+ const itemsToQpqPagedData = (items, lastEvaluatedKey) => ({
6
+ items,
7
+ lastEvaluatedKey: lastEvaluatedKey && (0, logs_1.stringToLastEvaluatedKey)(lastEvaluatedKey),
8
+ });
9
+ exports.itemsToQpqPagedData = itemsToQpqPagedData;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "quidproquo-actionprocessor-awslambda",
3
- "version": "0.0.115",
3
+ "version": "0.0.117",
4
4
  "description": "",
5
5
  "main": "./lib/index.js",
6
6
  "types": "./lib/index.d.js",