quidproquo-actionprocessor-awslambda 0.0.95 → 0.0.96

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.
@@ -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
- accessToken: authResult.AccessToken,
7
- idToken: authResult.IdToken,
8
- expiresIn: authResult.ExpiresIn,
9
- refreshToken: authResult.RefreshToken,
10
- tokenType: authResult.TokenType,
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
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "quidproquo-actionprocessor-awslambda",
3
- "version": "0.0.95",
3
+ "version": "0.0.96",
4
4
  "description": "",
5
5
  "main": "./lib/index.js",
6
6
  "types": "./lib/index.d.js",