Identify and avoid Exa anti-patterns and common integration mistakes. Use when reviewing Exa code for issues, onboarding new developers, or auditing existing Exa integrations for best practices violations. Trigger with phrases like "exa mistakes", "exa anti-patterns", "exa pitfalls", "exa what not to do", "exa code review".
View on GitHubjeremylongshore/claude-code-plugins-plus-skills
exa-pack
plugins/saas-packs/exa-pack/skills/exa-known-pitfalls/SKILL.md
February 1, 2026
Select agents to install to:
npx add-skill https://github.com/jeremylongshore/claude-code-plugins-plus-skills/blob/main/plugins/saas-packs/exa-pack/skills/exa-known-pitfalls/SKILL.md -a claude-code --skill exa-known-pitfallsInstallation paths:
.claude/skills/exa-known-pitfalls/# Exa Known Pitfalls
## Overview
Common mistakes and anti-patterns when integrating with Exa.
## Prerequisites
- Access to Exa codebase for review
- Understanding of async/await patterns
- Knowledge of security best practices
- Familiarity with rate limiting concepts
## Pitfall #1: Synchronous API Calls in Request Path
### ❌ Anti-Pattern
```typescript
// User waits for Exa API call
app.post('/checkout', async (req, res) => {
const payment = await exaClient.processPayment(req.body); // 2-5s latency
const notification = await exaClient.sendEmail(payment); // Another 1-2s
res.json({ success: true }); // User waited 3-7s
});
```
### ✅ Better Approach
```typescript
// Return immediately, process async
app.post('/checkout', async (req, res) => {
const jobId = await queue.enqueue('process-checkout', req.body);
res.json({ jobId, status: 'processing' }); // 50ms response
});
// Background job
async function processCheckout(data) {
const payment = await exaClient.processPayment(data);
await exaClient.sendEmail(payment);
}
```
---
## Pitfall #2: Not Handling Rate Limits
### ❌ Anti-Pattern
```typescript
// Blast requests, crash on 429
for (const item of items) {
await exaClient.process(item); // Will hit rate limit
}
```
### ✅ Better Approach
```typescript
import pLimit from 'p-limit';
const limit = pLimit(5); // Max 5 concurrent
const rateLimiter = new RateLimiter({ tokensPerSecond: 10 });
for (const item of items) {
await rateLimiter.acquire();
await limit(() => exaClient.process(item));
}
```
---
## Pitfall #3: Leaking API Keys
### ❌ Anti-Pattern
```typescript
// In frontend code (visible to users!)
const client = new ExaClient({
apiKey: 'sk_live_ACTUAL_KEY_HERE', // Anyone can see this
});
// In git history
git commit -m "add API key" // Exposed forever
```
### ✅ Better Approach
```typescript
// Backend only, environment variable
const client = new ExaClient({
apiKey: process.env.EXA_API_KEY,
});
// Use .gitignore
.env
.env