Learn more
We're thrilled to power the auth for Magic Eden and hundreds of thousands of NFT enthusiasts on its platform!
Table of contents
Enable customers to make transactions using one-time verification codes sent to their email. Set up a specific length for session keys to allow customers to complete transactions without needing a second verification step. One-time codes can be combined with Passkeys to let users optionally add a passkey as an additional security factor at a later date.
Passkeys offer an intuitive and step-forward experience for developers and users alike. Passkeys use popular keychain managers like iCloud or 1Password to safely secure and enable cross-device experience. In some cases, the experience of passkeys is still a few steps too advanced and developers want an alternative for their users to complete transactions using even more familiar functions. One-time codes offer a great solution.
Additionally, for customers that use Dynamic as an embedded solution across domains, the one-time code option offers flexibility as users would need to set up a passkey for each domain they interact with.
Using the authenticated email, Dynamic sends a secure one-time code (encoded in base65) at the time a transaction is initiated. This code must be pasted by the end-user and will grant them access to sign for transactions for their wallet. An encrypted key is stored in local storage based on a defined length (by the developer) so users can continue transacting without an additional prompt.
One-time codes can also be combined with passkeys.
What does the experience look if one-time codes are enabled:
The user logs in and has an embedded wallet created invisibly. At their first transaction or signing request, a one-time code is sent to their email. Once confirmed, the transaction will be processed. Users can continue transactions without an additional code until their session expires. Customers can add a passkey from their profile at any time.
How is this different from pre-generated wallets with passkeys?
If you do not enable one-time codes, customers must set up a passkey before their transaction will process.
How can I use one-time codes with Dynamic Embedded Wallets?
Use one-time codes as the primary or secondary method for signing transactions with your embedded wallet.
How do I enable this feature?
Go to dashboard > enable Dynamic embedded wallets > select one-time codes as a signing/security method.
How long does a session last?
This is a configurable field. It can be set to expire instantly or up to a few hours. It is your responsibility to evaluate how long the session key should last.
How is the Session key stored and Secured?
The session key is stored in a secure iframe hosted by our key-management provider which provides isolation as well as a layer of security to guarantee the session key is never directly accessible from malicious scripts, the developer, or even Dynamic.
Does the developer have access to the session key?
No. Wallets are non-custodial. The session key is never accessible by the developer.
Detailed Documentation: Go here.
Share this article