Web (JavaScript/TypeScript) - Auth
Interacting with Particle Auth within web applications using either JavaScript or TypeScript.
Particle Auth for Web Applications
Among all the SDKs for Particle Auth, the Web SDK (@particle-network/authkit
) is the most widely used. Thus, it offers extensive support and flexibility in driving onboarding through social logins, facilitating interaction with Particle’s Wallet-as-a-Service.
The Particle Auth SDK is the primary mechanism for configuring and using social logins. Whether you’re starting from scratch or already have an onboarding or authentication flow set up within your application, the Particle Auth Core Web SDK is a simple yet powerful integration.
Getting Started
Check out the Web Quickstart guide and get a new project up and running in just 5 minutes.
To get started with the Particle Auth Web SDK, you can add @particle-network/authkit
to your project using either of the two following mechanisms:
Configuration
Configuration is primarily handled by wrapping an application with Particle Auth’s master configuration component, essential for authenticating your project and customizing the optional embedded wallet modal.
No matter which Particle Auth SDK you’re using, you must define your projectId
, clientKey
, and appId
within this configuration object to authenticate your Particle Auth instance properly. Additionally, you can apply customizations to the wallet modal for a tailored user experience.
Follow the quickstart tutorial to set up a project and find the required keys: Create a new project.
Below is an example of an index.tsx
file from a create-react-app
project. In this example, the AuthCoreContextProvider
component acts as the configuration wrapper for the entire application.
Learn how to customize the aesthetics of the login and embedded wallet interface in the Customizing Login Modal and Customizing Wallet Modal pages.
When using a framework that supports React Server Components, you must include the "use client"
directive
at the beginning of the file.
Interaction with Web3
Now that you’ve configured an instance of Particle Auth, it’s time to leverage Particle to facilitate social logins and interactions with Web3.
To begin, you’ll need to choose between the following interaction mechanisms:
- Ethers.js.
- Web3.js.
- viem.
- Particle native.
They all achieve the same end goal of facilitating interaction with Web3, although they will result in a slightly different initialization process.
If you’ve chosen Particle native, no initialization of this nature is needed past configuring AuthCoreContextProvider
or ParticleNetwork
.
You can now use the provider object to interact with Web3, enabling actions like fetching account balances or sending transactions.
Initiating Social Login
To interact with a user’s account (wallet), they must first log in using Particle Auth or Particle Connect, similar to how one would enter a password and unlock MetaMask.
You can use the connect
and connected
functions from the useConnect()
hook to handle the connection logic:
In this example, the handleLogin
function initiates the login process by displaying the login modal if the connected
status is false
, indicating that the user is not currently logged in.
Customize the Login Experience
You can set specific configurations within the connect()
function to further tailor the login experience beyond frontend customizations.
The following example showcases all available configuration options:
web3.eth.getAccounts
will also initiate login automatically if a user isn’t already logged in.Log in with a Specific Social Platform
You can streamline the login process by bypassing the standard login modal and directing users to log in with a specific social platform.
The following example shows how to automatically prompt users to log in with their Google account, skipping the login modal entirely:
Login with JWT
You can use your existing user base or authentication method with Particle Auth through JWT. This way, your users can still log in with their current accounts.
Before connecting, you must set your custom JWT configuration on the Dashboard.
Then, you can refer to the code below to log in using JWT.
Learn more about Custom Authentication.
Implementation within a Telegram Miniapp
Check out the Telegram Mini-App Quickstart guide and get a new project up and running in just 5 minutes.
Before you start, ensure you’ve already created a Telegram Bot. Here is a comprehensive guide on how to do it.
Then, you need to create a Particle-Telegram app on Dashboard and get the config from the project information.
The following is an example of how you can connect with Telegram Miniapp.
Learn more about this:
Verify User Login Status
The useConnect()
hook provides several functions to check the user’s connection status:
-
connected
— Returns a boolean value indicating whether the user is logged in (true
) or not (false
). This is useful for managing login logic. -
connectionStatus
— Returns a string representing the current stage of the user’s flow:loading
connecting
connected
disconnected
You can use
connectionStatus
to manage login logic or to display relevant status information in the UI.
Handling User Information
Once the user is logged in, the userInfo
object from the useAuthCore()
hook becomes available.
connect()
will return the same object.For example, you can use it to display the user’s name
and avatar
, or access security details such as has_set_master_password
.
This allows you to implement logic that prompts the user to set a master password if they haven’t already done so, thereby improving security.
The following is an example of how you can render user information taken from userInfo
:
Retrieving the Public Address
To retrieve the public address linked to a user’s account, when it’s not already obtained through the login via userInfo
, you can use the following method:
Sending Transactions
Sending transactions using Particle as the Signer/underlying wallet is also quite simple.
If you’re using Ethers.js or Web3.js, you’re already set —as long as a user has logged in with Particle, transactions can be sent as you would with any other wallet.
When a given transaction is sent, and a signature is needed for authentication, a standard confirmation popup (also customizable through the Particle dashboard) will appear directly within the application. Transactions can be sent through the following:
To the end-user, sending transactions, regardless of the chosen method, looks like this (depending on customization outlined in the Particle dashboard).
Data Signing
In cases where you’d like to sign either a raw string (personal) or typed data (eth_signTypedData
), the process is quite straightforward.
You can accomplish this using standard libraries like Ethers or Web3.js or leveraging Particle’s native functionality. The examples below illustrate both approaches.
For instance, when sending transactions, the signatures are automatically formatted and presented to the user in a popup request. This ensures a user-friendly experience by displaying the relevant data in UTF-8 format.
Personal Signatures
Sign Typed Data
Enabling Blind Signatures
To enable blind signatures (signing without a confirmation popup) in Particle Auth, certain conditions must be met when configuring the AuthCoreContextProvider
component and setting up the authentication flow.
-
Master Password Requirement
- Users must either:
- Have entered the master password, or
- Not have set a master password in the first place.
- Users must either:
-
No Payment Password
- Users should not have set a payment password (as this interrupts the signing process).
-
Disable Payment Password Prompt Setting
- Set the
promptPaymentPasswordSettingWhenSign
parameter tofalse
withinAuthCoreContextProvider
.
- Set the
When these conditions are satisfied, blind signing is enabled.
Particle Native Hooks
Below is a collection of examples describing the different hooks available with Particle Auth.
These hooks facilitate social login and native application-level interaction (such as message signing, sending transactions, etc.) directly through Particle Auth.
useConnect
useConnect
acts as the primary hook for facilitating login (connection) with Particle Auth.
useEthereum
useEthereum
provides direct interaction with a given EVM chain as an alternative to a traditional library such as ethers or Web3.js.
useSolana
useSolana
is one of the primary ways to use Solana with Particle Auth if you aren’t using an external connection modal such as wallet-adapter
.
useAuthCore
useAuthCore
provides additional functionality, such as retrieving userInfo
after login, forcing different account menus to open, accessing the on-ramp page, and more.
useCustomize
useCustomize
provides several methods for customizing the wallet modal, such as changing the theme type (light or dark), creating a custom style, changing the language, and more.
External Connection Kits
Integrating and leveraging Particle Auth isn’t limited to interfaces provided by Particle Network; instead, it’s built to fit into nearly every implementation scenario. Whether you’re using RainbowKit, Web3Modal, or Solana’s wallet-adapter
or would like to have a standalone social login button within your application, Particle Auth can be used.
Was this page helpful?