UNPKG

@dynamic-labs/sdk-react-core

Version:

A React SDK for implementing wallet web3 authentication and authorization to your website.

78 lines (73 loc) 3.37 kB
'use client' 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _tslib = require('../../../../../_virtual/_tslib.cjs'); var email = require('../../../data/api/email/email.cjs'); require('@dynamic-labs/sdk-api-core'); require('@dynamic-labs/utils'); var storeAuthTokenAndUser = require('../../../store/state/user/storeAuthTokenAndUser/storeAuthTokenAndUser.cjs'); require('../../../store/state/user/user.cjs'); require('../../../config/ApiEndpoint.cjs'); require('../../../store/state/projectSettings/projectSettings.cjs'); require('../../../utils/constants/values.cjs'); require('@dynamic-labs/multi-wallet'); require('../../../shared/logger.cjs'); require('../../../utils/constants/colors.cjs'); require('react-international-phone'); require('@dynamic-labs/iconic'); require('@dynamic-labs/wallet-connector-core'); require('react'); require('react/jsx-runtime'); require('../../ViewContext/ViewContext.cjs'); require('@dynamic-labs/wallet-book'); require('../../../shared/consts/index.cjs'); require('../../../store/state/nonce/nonce.cjs'); require('../../../store/state/dynamicContextProps/dynamicContextProps.cjs'); require('../../../store/state/primaryWalletId/primaryWalletId.cjs'); require('../../../store/state/connectedWalletsInfo/connectedWalletsInfo.cjs'); require('../../../locale/locale.cjs'); const createEmailHandler = (environmentId, { shouldRegisterSessionKeysOnSignin, generateSessionKey, }) => (email$1, captchaToken) => _tslib.__awaiter(void 0, void 0, void 0, function* () { const createEmailVerificationResponse = yield email.createEmailVerification({ captchaToken, email: email$1, environmentId, }); let { verificationUUID } = createEmailVerificationResponse; return { retry: () => _tslib.__awaiter(void 0, void 0, void 0, function* () { const retryEmailVerificationResponse = yield email.retryEmailVerification({ email: email$1, environmentId, verificationUUID, }); // eslint-disable-next-line prefer-destructuring verificationUUID = retryEmailVerificationResponse.verificationUUID; }), type: 'email', verify: (oneTimePassword, options) => _tslib.__awaiter(void 0, void 0, void 0, function* () { let sessionPublicKey = undefined; if (shouldRegisterSessionKeysOnSignin()) { const keypair = yield generateSessionKey(); sessionPublicKey = keypair.publicKey; } const response = yield email.signInWithEmailVerification({ captchaToken, environmentId, sessionPublicKey, verificationToken: oneTimePassword, verificationUUID, }); // Skip setting the user auth token and only return the VerifyResponse // if needed because setUser can trigger view re-renders. if (!(options === null || options === void 0 ? void 0 : options.skipSetUserAndAuthToken)) { storeAuthTokenAndUser.storeAuthTokenAndUser(response); } return { destination: email$1, response: response, verified: true, }; }), }; }); exports.createEmailHandler = createEmailHandler;