Install
openclaw skills install dex-skillManage your Dex personal CRM — search, create, and update contacts, log interaction notes, set follow-up reminders, organize contacts with tags and groups, a...
openclaw skills install dex-skillDex is a personal CRM that helps users maintain and nurture their professional relationships. It tracks contacts, interaction history, reminders, and organizational structures (groups, tags, custom fields).
Check which access method is available, in this order:
dex_search_contacts and other dex_* tools are in the tool list, use MCP tools directly. This is the preferred method — skip CLI setup entirely.dex command exists (run which dex or dex auth status). If authenticated, use CLI commands.Path A — Platform supports MCP (Claude Desktop, Cursor, VS Code, Gemini CLI, etc.):
If the user already has the Dex MCP server configured, or their platform can add MCP servers:
npx -y add-mcp https://mcp.getdex.com/mcp -y
This auto-detects installed AI clients and configures the Dex MCP server for all of them. User authenticates via browser on first MCP connection.
Path B — Install CLI:
npm install -g @getdex/cli
Works with npm, pnpm, and yarn. No postinstall scripts — the binary is bundled in a platform-specific package.
Keeping the CLI up to date:
The CLI auto-generates commands from the MCP server's tool schemas at build time. When tools are added or updated on the server, users need to update the CLI to get the new commands. If a user reports a missing command or parameter, suggest updating:
npm install -g @getdex/cli@latest
Path C — No Node.js:
Direct the user to follow the setup guide at https://getdex.com/docs/ai/mcp-server — it has client-specific instructions for Claude Desktop, Claude Code, Cursor, VS Code, and other MCP-capable clients.
Triggered by /dex-login or on first use when not authenticated. Ask the user which method they prefer:
Option 1 — API Key:
dex auth --token dex_your_key_here~/.dex/api-key (chmod 600)Option 2 — Device Code Flow (works on remote/headless machines):
Drive this flow directly via HTTP — no browser needed on the machine:
Request a device code:
curl -s -X POST https://mcp.getdex.com/device/code -H "Content-Type: application/json"
Response: { "device_code": "...", "user_code": "ABCD-EFGH", "verification_uri": "https://...", "expires_in": 600, "interval": 5 }
Show the user the user_code and verification_uri. They open the URL on any device with a browser, log in to Dex, and enter the code.
Poll for approval every 5 seconds:
curl -s -X POST https://mcp.getdex.com/device/token \
-H "Content-Type: application/json" \
-d '{"device_code": "<device_code>"}'
{"error": "authorization_pending"} → keep polling{"api_key": "dex_..."} → done, save the keySave the API key:
mkdir -p ~/.dex && echo "<api_key>" > ~/.dex/api-key && chmod 600 ~/.dex/api-key
For CLI: dex auth --token <api_key>
For CI/automation with no human present, use the API key method with DEX_API_KEY environment variable.
Contact
├── Emails, Phone Numbers, Social Profiles
├── Company, Job Title, Birthday, Website
├── Description (rich text notes about the person)
├── Tags (flat labels: "Investor", "College Friend")
├── Groups (collections with emoji + description: "🏢 Acme Team")
├── Custom Fields (user-defined: input, dropdown, datepicker)
├── Notes/Timeline (interaction log: meetings, calls, coffees)
├── Reminders (follow-up tasks with optional recurrence)
└── Starred / Archived status
Call dex_* tools directly. All tools accept and return JSON.
Use the dex command. CLIHub generates subcommands from MCP tool names (replacing _ with -):
dex dex-search-contacts --query "John"
dex dex-list-contacts --limit 100
dex dex-create-contact --first-name "Jane" --last-name "Doe"
dex dex-list-tags
dex dex-create-reminder --text "Follow up" --due-at-date "2026-03-15"
Use --output json for machine-readable output, --output text (default) for human-readable.
Run dex --help for all commands, or dex <command> --help for command-specific help.
See CLI Command Reference for the full mapping table of all 38 tools to CLI commands.
search → get details (with notes if needed)
dex_list_contacts for bulk iteration (up to 500 per page, cursor-paginated)include_notes: true when user needs interaction historycreate contact → (optionally) add to groups → apply tags → set reminder
Bulk import (CSV, spreadsheet, list):
batch create contacts → add to group → create note for all
dex_create_contact with the contacts array (up to 100 per call) for batch creationdex_add_contacts_to_groupdex_create_note with contact_ids to log a shared note across all imported contacts(optional) list note types → create note on contact timeline
dex_list_note_types to pick the right one (Meeting, Call, Coffee, Note, etc.)event_time to when the interaction happened, not when logging itcontact_ids (plural) to link a single note to multiple contacts (e.g. a group meeting)create reminder → (link to contact if applicable)
due_at_date (ISO format: "2026-03-15")text for the reminder description — there is no separate title fieldweekly, biweekly, monthly, quarterly, biannually, yearlyTags — flat labels for cross-cutting categories:
create tag → add to contacts (bulk)
Groups — named collections with emoji and description:
create group → add contacts (bulk)
Best practice: Use tags for attributes ("Investor", "Engineer", "Met at Conference X") and groups for relationship clusters ("Startup Advisors", "Book Club", "Acme Corp Team").
list fields → create field definition → batch set values on contacts
input (free text), autocomplete (dropdown with options), datepickerdex_set_custom_field_values to set values on multiple contacts at oncecategories array with the allowed optionsWhen a user says "I have a meeting with X":
include_notes: truesearch for potential duplicates → confirm with user → merge
List operations use cursor-based pagination:
dex_list_contacts: default 100 per page, max 500dex_search_contacts: default 50 per page, max 200has_more in responsenext_cursor from previous response to get next pagehas_more: false to get all resultsAlways confirm with the user before:
dex_delete_contacts)dex_merge_contacts)Responses are capped at 25,000 characters. If truncated, the response preserves pagination metadata (next_cursor, has_more) so you can fetch the next page. Use smaller limit values if responses are being truncated.
"2026-03-15", "2026-03-15T14:30:00Z")YYYY-MM-DDYYYY-MM-DDnpm i -g @getdex/cli