Authenticating with the Payments Wallet
When the wallet is not signed in (detected via npx awal status or when wallet operations fail with authentication errors), use the npx awal CLI to authenticate.
If you have access to email, you can authenticate the wallet yourself, otherwise you'll need to ask your human to give you an email address and to tell you the OTP code they receive.
Authentication Flow
Authentication uses a two-step email OTP process:
Step 1: Initiate login
npx [email protected] auth login <email>
This sends a 6-digit verification code to the email and outputs a flowId.
Step 2: Verify OTP
npx [email protected] auth verify <flowId> <otp>
Use the flowId from step 1 and the 6-digit code from the user's email to complete authentication. If you have the ability to access the user's email, you can read the OTP code, or you can ask your human for the code.
Input Validation
Before constructing the command, validate all user-provided values to prevent shell injection:
- email: Must match a standard email format (
^[^\s;|&]+@[^\s;|&]+$). Reject if it contains spaces, semicolons, pipes, backticks, or other shell metacharacters. - flowId: Must be alphanumeric (
^[a-zA-Z0-9_-]+$). - otp: Must be exactly 6 digits (
^\d{6}$).
Do not pass unvalidated user input into the command.
Checking Authentication Status
npx [email protected] status
Displays wallet server health and authentication status including wallet address.
Example Session
# Check current status npx [email protected] status # Start login (sends OTP to email) npx [email protected] auth login [email protected] # Output: flowId: abc123... # After user receives code, verify npx [email protected] auth verify abc123 123456 # Confirm authentication npx [email protected] status
Available CLI Commands
| Command | Purpose |
|---|---|
npx [email protected] status | Check server health and auth status |
npx [email protected] auth login <email> | Send OTP code to email, returns flowId |
npx [email protected] auth verify <flowId> <otp> | Complete authentication with OTP code |
npx [email protected] balance | Get USDC wallet balance |
npx [email protected] address | Get wallet address |
npx [email protected] show | Open the wallet companion window |
JSON Output
All commands support --json for machine-readable output:
npx [email protected] status --json npx [email protected] auth login [email protected] --json npx [email protected] auth verify <flowId> <otp> --json