@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
JavaScript
'use client'
;
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;