Execute Exa neural search with contents, date filters, and domain scoping. Use when building search features, implementing RAG context retrieval, or querying the web with semantic understanding. Trigger with phrases like "exa search", "exa neural search", "search with exa", "exa searchAndContents", "exa query".
Use the skills CLI to install this skill with one command. Auto-detects all installed AI assistants.
Method 1 - skills CLI
npx skills i jeremylongshore/claude-code-plugins-plus-skills/plugins/saas-packs/exa-pack/skills/exa-core-workflow-aMethod 2 - openskills (supports sync & update)
npx openskills install jeremylongshore/claude-code-plugins-plus-skillsAuto-detects Claude Code, Cursor, Codex CLI, Gemini CLI, and more. One install, works everywhere.
Installation Path
Download and extract to one of the following locations:
No setup needed. Let our cloud agents run this skill for you.
Select Provider
Select Model
Best for coding tasks
No setup required
Primary workflow for Exa: semantic web search using search() and searchAndContents(). Exa's neural search understands query meaning rather than matching keywords, making it ideal for research, RAG pipelines, and content discovery. This skill covers search types, content extraction, filtering, and categories.
exa-js installed and EXA_API_KEY configured| Type | Latency | Best For |
|---|---|---|
auto (default) | 300-1500ms | General queries; Exa picks best approach |
neural | 500-2000ms | Conceptual/semantic queries |
keyword | 200-500ms | Exact terms, names, URLs |
fast | p50 < 425ms | Speed-critical applications |
instant | < 150ms | Real-time autocomplete |
deep | 2-5s | Maximum quality, light deep search |
deep-reasoning | 5-15s | Complex research questions |
import Exa from "exa-js";
const exa = new Exa(process.env.EXA_API_KEY);
// Neural search: phrase your query as a statement, not a question
const results = await exa.search(
"comprehensive guide to building production RAG systems",
{
type: "neural",
numResults: 10
// searchAndContents returns page text, highlights, and/or summaries
const results = await exa.searchAndContents(
"best practices for vector database selection",
{
type: "auto",
numResults: 5,
// Text: full page content as markdown
text: { maxCharacters: 2000 },
// Highlights: key excerpts relevant to a custom query
highlights: {
// Filter by publication date and restrict to specific domains
const results = await exa.searchAndContents(
"TypeScript 5.5 new features",
{
type: "auto",
numResults: 10,
// Date filters use ISO 8601 format
startPublishedDate: "2024-06-01T00:00:00.000Z",
endPublishedDate: "2025-01-01T00:00:00.000Z",
// Domain filters (up to 1200 domains each)
includeDomains: [
// Categories narrow results to specific content types
// Available: company, research paper, news, tweet, personal site,
// financial report, people
const papers = await exa.searchAndContents(
"attention mechanism improvements for long context LLMs",
{
type: "neural",
numResults: 10,
category: "research paper",
text: { maxCharacters: 3000 },
// Control whether Exa fetches fresh content or uses cache
const results = await exa.searchAndContents(
"latest AI model releases this week",
{
numResults: 5,
text: { maxCharacters: 1500 },
// maxAgeHours controls freshness (replaces deprecated livecrawl)
// 0 = always crawl fresh, -1 = never crawl, positive = max cache age
livecrawl: "preferred", // try fresh, fall back to cache
livecrawlTimeout: 10000,
| Error | HTTP Code | Cause | Solution |
|---|---|---|---|
INVALID_REQUEST_BODY | 400 | Invalid parameter types | Check query is string, numResults is integer |
INVALID_NUM_RESULTS | 400 | numResults > 100 with highlights | Reduce numResults or remove highlights |
| Empty results array | 200 | Date filter too narrow | Widen date range or remove filter |
| Low relevance scores | 200 | Keyword-style query | Rephrase as natural language statement |
async function getRAGContext(question: string, maxResults = 5) {
const results = await exa.searchAndContents(question, {
type: "neural",
numResults: maxResults,
text: { maxCharacters: 2000 },
highlights: { maxCharacters: 500, query: question },
});
For similarity search and advanced retrieval, see exa-core-workflow-b.
FETCH_DOCUMENT_ERROR | 422 | URL content unretrievable | Use livecrawl: "fallback" or try without text |