quidproquo-actionprocessor-awslambda 0.0.95 → 0.0.97
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/lib/getActionProcessor/core/system/getExecuteStoryActionProcessor.js +1 -1
- package/lib/getActionProcessor/webserver/admin/getAdminActionProcessor.d.ts +2 -1
- package/lib/getActionProcessor/webserver/admin/getAdminActionProcessor.js +11 -1
- package/lib/getActionProcessor/webserver/admin/index.d.ts +1 -0
- package/lib/logic/cognito/authenticateUser.js +3 -1
- package/lib/logic/cognito/refreshToken.js +3 -1
- package/lib/logic/cognito/utils/transformCognitoResponse.d.ts +2 -2
- package/lib/logic/cognito/utils/transformCognitoResponse.js +16 -9
- package/lib/logic/dynamo/getLogChildrenByFromCorrelation.js +5 -2
- package/package.json +1 -1
|
@@ -27,7 +27,7 @@ const getProcessExecuteStory = (qpqConfig, dynamicModuleLoader) => {
|
|
|
27
27
|
}
|
|
28
28
|
const resolveStory = (0, quidproquo_core_1.createRuntime)(qpqConfig, session, actionProcessors, exports.getDateNow, logger,
|
|
29
29
|
// TODO: Share this logic.
|
|
30
|
-
`${moduleName}
|
|
30
|
+
`${moduleName}::${(0, awsLambdaUtils_1.randomGuid)()}`, quidproquo_core_1.QpqRuntimeType.EXECUTE_STORY, [`${payload.src}::${payload.runtime}`]);
|
|
31
31
|
const storyResult = yield resolveStory(story, payload.params);
|
|
32
32
|
if (storyResult.error) {
|
|
33
33
|
return (0, quidproquo_core_1.actionResultError)(storyResult.error.errorType, storyResult.error.errorText, `story error! in ${payload.src}::${payload.runtime} -> [${storyResult.error.errorStack}]`);
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { QPQConfig } from 'quidproquo-core';
|
|
2
|
-
import { AdminGetLogsActionProcessor, AdminGetLogActionProcessor, AdminGetLogMetadataChildrenActionProcessor } from 'quidproquo-webserver';
|
|
2
|
+
import { AdminGetLogsActionProcessor, AdminGetLogActionProcessor, AdminGetLogMetadataChildrenActionProcessor, AdminGetLogMetadataActionProcessor } from 'quidproquo-webserver';
|
|
3
3
|
declare const _default: (qpqConfig: QPQConfig) => {
|
|
4
4
|
"@quidproquo-webserver/Admin/GetLogs": AdminGetLogsActionProcessor;
|
|
5
5
|
"@quidproquo-webserver/Admin/GetLog": AdminGetLogActionProcessor;
|
|
6
6
|
"@quidproquo-webserver/Admin/GetLogMetadataChildren": AdminGetLogMetadataChildrenActionProcessor;
|
|
7
|
+
"@quidproquo-webserver/Admin/GetLogMetadata": AdminGetLogMetadataActionProcessor;
|
|
7
8
|
};
|
|
8
9
|
export default _default;
|
|
@@ -14,6 +14,7 @@ const quidproquo_webserver_1 = require("quidproquo-webserver");
|
|
|
14
14
|
const awsNamingUtils_1 = require("../../../awsNamingUtils");
|
|
15
15
|
const getPagedItemsOverRange_1 = require("../../../logic/dynamo/getPagedItemsOverRange");
|
|
16
16
|
const getLogChildrenByFromCorrelation_1 = require("../../../logic/dynamo/getLogChildrenByFromCorrelation");
|
|
17
|
+
const getLogByCorrelation_1 = require("../../../logic/dynamo/getLogByCorrelation");
|
|
17
18
|
const readTextFile_1 = require("../../../logic/s3/readTextFile");
|
|
18
19
|
// TODO: Centralize this
|
|
19
20
|
const QPQ_LOG_BUCKET_NAME = 'logs';
|
|
@@ -27,12 +28,20 @@ const getAdminGetLogsActionProcessor = (qpqConfig) => {
|
|
|
27
28
|
};
|
|
28
29
|
const getLogMetadataChildrenActionProcessor = (qpqConfig) => {
|
|
29
30
|
return ({ correlationId }) => __awaiter(void 0, void 0, void 0, function* () {
|
|
30
|
-
const tableName = (0, awsNamingUtils_1.getQpqRuntimeResourceNameFromConfig)(QPQ_LOG_BUCKET_NAME, qpqConfig, '
|
|
31
|
+
const tableName = (0, awsNamingUtils_1.getQpqRuntimeResourceNameFromConfig)(QPQ_LOG_BUCKET_NAME, qpqConfig, 'flog');
|
|
31
32
|
const region = quidproquo_core_1.qpqCoreUtils.getApplicationModuleDeployRegion(qpqConfig);
|
|
32
33
|
const response = yield (0, getLogChildrenByFromCorrelation_1.getLogChildrenByFromCorrelation)(tableName, region, correlationId);
|
|
33
34
|
return (0, quidproquo_core_1.actionResult)(response);
|
|
34
35
|
});
|
|
35
36
|
};
|
|
37
|
+
const getLogMetadataActionProcessor = (qpqConfig) => {
|
|
38
|
+
return ({ correlationId }) => __awaiter(void 0, void 0, void 0, function* () {
|
|
39
|
+
const tableName = (0, awsNamingUtils_1.getQpqRuntimeResourceNameFromConfig)(QPQ_LOG_BUCKET_NAME, qpqConfig, 'log');
|
|
40
|
+
const region = quidproquo_core_1.qpqCoreUtils.getApplicationModuleDeployRegion(qpqConfig);
|
|
41
|
+
const response = yield (0, getLogByCorrelation_1.getLogByCorrelation)(tableName, region, correlationId);
|
|
42
|
+
return (0, quidproquo_core_1.actionResult)(response);
|
|
43
|
+
});
|
|
44
|
+
};
|
|
36
45
|
const getAdminGetLogActionProcessor = (qpqConfig) => {
|
|
37
46
|
return ({ correlationId }) => __awaiter(void 0, void 0, void 0, function* () {
|
|
38
47
|
const bucketName = (0, awsNamingUtils_1.getQpqRuntimeResourceNameFromConfig)(QPQ_LOG_BUCKET_NAME, qpqConfig, 'log');
|
|
@@ -47,5 +56,6 @@ exports.default = (qpqConfig) => {
|
|
|
47
56
|
[quidproquo_webserver_1.AdminActionType.GetLogs]: getAdminGetLogsActionProcessor(qpqConfig),
|
|
48
57
|
[quidproquo_webserver_1.AdminActionType.GetLog]: getAdminGetLogActionProcessor(qpqConfig),
|
|
49
58
|
[quidproquo_webserver_1.AdminActionType.GetLogMetadataChildren]: getLogMetadataChildrenActionProcessor(qpqConfig),
|
|
59
|
+
[quidproquo_webserver_1.AdminActionType.GetLogMetadata]: getLogMetadataActionProcessor(qpqConfig),
|
|
50
60
|
};
|
|
51
61
|
};
|
|
@@ -3,5 +3,6 @@ declare const _default: (qpqConfig: QPQConfig) => {
|
|
|
3
3
|
"@quidproquo-webserver/Admin/GetLogs": import("quidproquo-webserver/lib").AdminGetLogsActionProcessor;
|
|
4
4
|
"@quidproquo-webserver/Admin/GetLog": import("quidproquo-webserver/lib").AdminGetLogActionProcessor;
|
|
5
5
|
"@quidproquo-webserver/Admin/GetLogMetadataChildren": import("quidproquo-webserver/lib").AdminGetLogMetadataChildrenActionProcessor;
|
|
6
|
+
"@quidproquo-webserver/Admin/GetLogMetadata": import("quidproquo-webserver/lib").AdminGetLogMetadataActionProcessor;
|
|
6
7
|
};
|
|
7
8
|
export default _default;
|
|
@@ -20,6 +20,8 @@ const authenticateUser = (userPoolId, clientId, region, username, password) => _
|
|
|
20
20
|
const cognitoClient = new client_cognito_identity_provider_1.CognitoIdentityProviderClient({ region });
|
|
21
21
|
const clientSecret = yield (0, getUserPoolClientSecret_1.getUserPoolClientSecret)(userPoolId, clientId, region);
|
|
22
22
|
const secretHash = (0, calculateSecretHash_1.calculateSecretHash)(username, clientId, clientSecret);
|
|
23
|
+
// Time we issued the request
|
|
24
|
+
const issueDateTime = new Date().toISOString();
|
|
23
25
|
const params = {
|
|
24
26
|
AuthFlow: client_cognito_identity_provider_1.AuthFlowType.ADMIN_USER_PASSWORD_AUTH,
|
|
25
27
|
UserPoolId: userPoolId,
|
|
@@ -32,7 +34,7 @@ const authenticateUser = (userPoolId, clientId, region, username, password) => _
|
|
|
32
34
|
};
|
|
33
35
|
try {
|
|
34
36
|
const response = yield cognitoClient.send(new client_cognito_identity_provider_1.AdminInitiateAuthCommand(params));
|
|
35
|
-
return (0, transformCognitoResponse_1.cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo)(response);
|
|
37
|
+
return (0, transformCognitoResponse_1.cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo)(response, issueDateTime);
|
|
36
38
|
}
|
|
37
39
|
catch (e) {
|
|
38
40
|
if (e instanceof Error) {
|
|
@@ -27,7 +27,9 @@ const refreshToken = (userPoolId, clientId, region, username, refreshToken) => _
|
|
|
27
27
|
SECRET_HASH: secretHash,
|
|
28
28
|
},
|
|
29
29
|
};
|
|
30
|
+
// Time we issued the request
|
|
31
|
+
const issueDateTime = new Date().toISOString();
|
|
30
32
|
const response = yield cognitoClient.send(new client_cognito_identity_provider_1.AdminInitiateAuthCommand(params));
|
|
31
|
-
return (0, transformCognitoResponse_1.cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo)(response);
|
|
33
|
+
return (0, transformCognitoResponse_1.cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo)(response, issueDateTime);
|
|
32
34
|
});
|
|
33
35
|
exports.refreshToken = refreshToken;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { AuthenticateUserResponse, AuthenticationInfo } from 'quidproquo-core';
|
|
2
2
|
import { AuthenticationResultType, AdminInitiateAuthResponse } from '@aws-sdk/client-cognito-identity-provider';
|
|
3
|
-
export declare const cognitoAuthenticationResultTypeToQpqAuthenticationInfo: (authResult: AuthenticationResultType) => AuthenticationInfo;
|
|
4
|
-
export declare const cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo: (authResponse: AdminInitiateAuthResponse) => AuthenticateUserResponse;
|
|
3
|
+
export declare const cognitoAuthenticationResultTypeToQpqAuthenticationInfo: (authResult: AuthenticationResultType, issueDateTime: string) => AuthenticationInfo;
|
|
4
|
+
export declare const cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo: (authResponse: AdminInitiateAuthResponse, issueDateTime: string) => AuthenticateUserResponse;
|
|
@@ -2,21 +2,28 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo = exports.cognitoAuthenticationResultTypeToQpqAuthenticationInfo = void 0;
|
|
4
4
|
const quidproquo_core_1 = require("quidproquo-core");
|
|
5
|
-
const cognitoAuthenticationResultTypeToQpqAuthenticationInfo = (authResult) =>
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
5
|
+
const cognitoAuthenticationResultTypeToQpqAuthenticationInfo = (authResult, issueDateTime) => {
|
|
6
|
+
// Parse the issueDateTime and add the expiresIn to get the expiration date
|
|
7
|
+
let issueDate = new Date(issueDateTime);
|
|
8
|
+
issueDate.setSeconds(issueDate.getSeconds() + (authResult.ExpiresIn || 0));
|
|
9
|
+
const expiresAt = issueDate.toISOString();
|
|
10
|
+
return {
|
|
11
|
+
accessToken: authResult.AccessToken,
|
|
12
|
+
idToken: authResult.IdToken,
|
|
13
|
+
refreshToken: authResult.RefreshToken,
|
|
14
|
+
tokenType: authResult.TokenType,
|
|
15
|
+
expirationDurationInSeconds: authResult.ExpiresIn,
|
|
16
|
+
expiresAt,
|
|
17
|
+
};
|
|
18
|
+
};
|
|
12
19
|
exports.cognitoAuthenticationResultTypeToQpqAuthenticationInfo = cognitoAuthenticationResultTypeToQpqAuthenticationInfo;
|
|
13
|
-
const cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo = (authResponse) => {
|
|
20
|
+
const cognitoAdminInitiateAuthResponseToQpqAuthenticationInfo = (authResponse, issueDateTime) => {
|
|
14
21
|
const res = {
|
|
15
22
|
session: authResponse.Session,
|
|
16
23
|
challenge: quidproquo_core_1.AuthenticateUserChallenge.NONE,
|
|
17
24
|
};
|
|
18
25
|
if (authResponse.AuthenticationResult) {
|
|
19
|
-
res.authenticationInfo = (0, exports.cognitoAuthenticationResultTypeToQpqAuthenticationInfo)(authResponse.AuthenticationResult);
|
|
26
|
+
res.authenticationInfo = (0, exports.cognitoAuthenticationResultTypeToQpqAuthenticationInfo)(authResponse.AuthenticationResult, issueDateTime);
|
|
20
27
|
}
|
|
21
28
|
return res;
|
|
22
29
|
};
|
|
@@ -17,8 +17,11 @@ function getLogChildrenByFromCorrelation(tableName, region, fromCorrelation, pag
|
|
|
17
17
|
const dynamoDBClient = new client_dynamodb_1.DynamoDBClient({ region });
|
|
18
18
|
const queryParams = {
|
|
19
19
|
TableName: tableName,
|
|
20
|
-
IndexName
|
|
21
|
-
KeyConditionExpression: 'fromCorrelation = :fromCorrelation',
|
|
20
|
+
// removed IndexName
|
|
21
|
+
KeyConditionExpression: '#fromCorrelation = :fromCorrelation',
|
|
22
|
+
ExpressionAttributeNames: {
|
|
23
|
+
'#fromCorrelation': 'fromCorrelation', // define attribute name
|
|
24
|
+
},
|
|
22
25
|
ExpressionAttributeValues: {
|
|
23
26
|
':fromCorrelation': { S: fromCorrelation },
|
|
24
27
|
},
|