Methodologygeneric

authenticate-wallet

Sign in to the wallet. Use when you or the user want to log in, sign in, connect, or set up the wallet, or when any wallet operation fails with authentication or "not signed in" errors. This skill is a prerequisite before sending, trading, or funding.

coinbase/agentic-wallet-skills
View source

Install

npx skills add https://github.com/coinbase/agentic-wallet-skills --skill authenticate-wallet

Use with your agent

ClaudeCursorOpenAIGemini

Install the authenticate-wallet skill, then use it as build context. Run: npx skills add https://github.com/coinbase/agentic-wallet-skills --skill authenticate-wallet. Then read the installed skill.md and follow its guidance to build or refactor my project.

Authenticating with the Agentic 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 <otp>

Use the 6-digit code from the user's email to complete authentication. The flow ID from step 1 is saved automatically to a local file — you do not pass it as an argument. 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.
  • 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 (flow ID saved automatically)
npx [email protected] auth verify 123456

# Confirm authentication
npx [email protected] status

Available CLI Commands

CommandPurpose
npx [email protected] statusCheck server health and auth status
npx [email protected] auth login <email>Send OTP code to email, returns flowId
npx [email protected] auth verify <otp>Complete authentication with OTP code
npx [email protected] balanceGet balances across Base, Polygon, and Solana (use --chain for a single chain)
npx [email protected] addressGet wallet address
npx [email protected] showOpen 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 <otp> --json