Identify and avoid Retell AI anti-patterns and common integration mistakes. Use when reviewing Retell AI code for issues, onboarding new developers, or auditing existing Retell AI integrations for best practices violations. Trigger with phrases like "retellai mistakes", "retellai anti-patterns", "retellai pitfalls", "retellai what not to do", "retellai code review".
View on GitHubjeremylongshore/claude-code-plugins-plus-skills
retellai-pack
plugins/saas-packs/retellai-pack/skills/retellai-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/retellai-pack/skills/retellai-known-pitfalls/SKILL.md -a claude-code --skill retellai-known-pitfallsInstallation paths:
.claude/skills/retellai-known-pitfalls/# Retell AI Known Pitfalls
## Overview
Common mistakes and anti-patterns when integrating with Retell AI.
## Prerequisites
- Access to Retell AI 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 Retell AI API call
app.post('/checkout', async (req, res) => {
const payment = await retellaiClient.processPayment(req.body); // 2-5s latency
const notification = await retellaiClient.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 retellaiClient.processPayment(data);
await retellaiClient.sendEmail(payment);
}
```
---
## Pitfall #2: Not Handling Rate Limits
### ❌ Anti-Pattern
```typescript
// Blast requests, crash on 429
for (const item of items) {
await retellaiClient.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(() => retellaiClient.process(item));
}
```
---
## Pitfall #3: Leaking API Keys
### ❌ Anti-Pattern
```typescript
// In frontend code (visible to users!)
const client = new RetellAIClient({
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 RetellAIClient({
a