UNPKG

@dynamic-labs/sdk-react-core

Version:

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

69 lines (64 loc) 2.89 kB
'use client' 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _tslib = require('../../../../../_virtual/_tslib.cjs'); require('@dynamic-labs/utils'); require('@dynamic-labs/sdk-api-core'); 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'); var storeAuthTokenAndUser = require('../../../store/state/user/storeAuthTokenAndUser/storeAuthTokenAndUser.cjs'); require('../../../store/state/user/user.cjs'); require('../../../store/state/connectedWalletsInfo/connectedWalletsInfo.cjs'); var sms = require('../../../data/api/sms/sms.cjs'); const createSmsHandler = (environmentId, { shouldRegisterSessionKeysOnSignin, generateSessionKey, }) => (phone, captchaToken) => _tslib.__awaiter(void 0, void 0, void 0, function* () { const { verificationUUID } = yield sms.createSmsVerification({ captchaToken, environmentId, isoCountryCode: phone.iso2, phoneCountryCode: phone.dialCode, phoneNumber: phone.phone, }); return { type: 'sms', 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 sms.signInWithSmsVerification({ 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: phone, response: response, verified: true, }; }), }; }); exports.createSmsHandler = createSmsHandler;