farcaster-skill
Post, read, search, and engage on Farcaster via the Neynar API. Use when an agent needs to: (1) post casts with text, embeds, or in channels, (2) reply to or thread casts, (3) read a user's feed or a channel feed, (4) search casts by keyword, (5) look up user profiles by username or FID, (6) like or recast, (7) delete casts, (8) list or search channels. Pure bash+curl+jq — zero npm dependencies.
Install
mkdir -p .claude/skills/farcaster-skill && curl -L -o skill.zip "https://mcp.directory/api/skills/download/6964" && unzip -o skill.zip -d .claude/skills/farcaster-skill && rm skill.zipInstalls to .claude/skills/farcaster-skill
About this skill
Farcaster Skill (Neynar v2)
All scripts use the Neynar v2 REST API. Requires curl and jq.
Setup
Set these env vars (or pass --api-key / --signer flags):
export NEYNAR_API_KEY="your-api-key"
export NEYNAR_SIGNER_UUID="your-signer-uuid" # required for write ops
Alternatively, put credentials in a JSON file and source them:
eval $(jq -r '"export NEYNAR_API_KEY=\(.apiKey)\nexport NEYNAR_SIGNER_UUID=\(.signerUuid)"' /path/to/neynar.json)
Scripts
fc_cast.sh — Post a Cast
Post text, with optional embeds, channel, or reply-to.
# Simple text cast
scripts/fc_cast.sh --text "Hello Farcaster!"
# Cast with image/video embed
scripts/fc_cast.sh --text "Check this out" --embed "https://example.com/image.png"
# Cast with two embeds (max 2)
scripts/fc_cast.sh --text "Links" --embed "https://a.com" --embed "https://b.com"
# Post to a channel
scripts/fc_cast.sh --text "gm" --channel "base"
# Reply to a cast
scripts/fc_cast.sh --text "Great point!" --parent "0xabcdef1234..."
# Quote-cast (embed another cast)
scripts/fc_cast.sh --text "This 👆" --embed-cast "0xabcdef1234..." --embed-cast-fid 12345
Output: JSON {success, hash}.
fc_feed.sh — Read Feeds
# User's casts by FID
scripts/fc_feed.sh --fid 3 --limit 10
# User's casts by username
scripts/fc_feed.sh --username "vitalik" --limit 5
# Channel feed
scripts/fc_feed.sh --channel "base" --limit 10
# Following feed (casts from people the signer follows)
scripts/fc_feed.sh --following --fid 3 --limit 10
# Cast replies/thread
scripts/fc_feed.sh --thread "0xabcdef..."
# Pagination with cursor
scripts/fc_feed.sh --fid 3 --cursor "eyJwYWdlIjoxfQ=="
Output: JSON array of casts with {hash, author, text, timestamp, embeds, reactions, replies}.
fc_user.sh — User Lookup
# By username
scripts/fc_user.sh --username "dwr"
# By FID
scripts/fc_user.sh --fid 3
# By Ethereum address (verified)
scripts/fc_user.sh --address "0x1234..."
# Bulk by FIDs
scripts/fc_user.sh --fids "3,194,6131"
Output: JSON user object(s) with {fid, username, display_name, bio, follower_count, following_count, verified_addresses}.
fc_search.sh — Search Casts
# Search by keyword
scripts/fc_search.sh --query "base chain"
# Search with author filter
scripts/fc_search.sh --query "ethereum" --author-fid 3
# Search in channel
scripts/fc_search.sh --query "gm" --channel "base"
# Limit results
scripts/fc_search.sh --query "nft" --limit 5
Output: JSON array of matching casts.
fc_react.sh — Like / Recast
# Like a cast
scripts/fc_react.sh --like "0xabcdef..."
# Unlike
scripts/fc_react.sh --like "0xabcdef..." --undo
# Recast
scripts/fc_react.sh --recast "0xabcdef..."
# Undo recast
scripts/fc_react.sh --recast "0xabcdef..." --undo
fc_delete.sh — Delete a Cast
scripts/fc_delete.sh --hash "0xabcdef..."
fc_channels.sh — List and Search Channels
# Search channels by keyword
scripts/fc_channels.sh --search "defi"
# Get channel details by ID
scripts/fc_channels.sh --id "base"
# List trending channels
scripts/fc_channels.sh --trending --limit 10
Common Patterns
Thread a multi-cast announcement
HASH1=$(scripts/fc_cast.sh --text "Thread 🧵 1/3: Big news!" --channel "base" | jq -r .hash)
HASH2=$(scripts/fc_cast.sh --text "2/3: Details here..." --parent "$HASH1" | jq -r .hash)
scripts/fc_cast.sh --text "3/3: Link below" --parent "$HASH2" --embed "https://example.com"
Monitor mentions (poll loop)
while true; do
scripts/fc_search.sh --query "@yourusername" --limit 5
sleep 300
done
Post with media (upload first, then embed)
# Upload to catbox/litterbox first
URL=$(curl -sS -F "reqtype=fileupload" -F "time=72h" \
-F "fileToUpload=@/path/to/image.png" \
https://litterbox.catbox.moe/resources/internals/api.php)
# Then embed the URL
scripts/fc_cast.sh --text "Check this out!" --embed "$URL"
Free vs Paid Tier
Not all endpoints are available on Neynar's free plan.
| Feature | Script | Free? |
|---|---|---|
| Post cast | fc_cast.sh | ✅ |
| User casts feed | fc_feed.sh --fid | ✅ |
| User lookup (username/FID/address) | fc_user.sh | ✅ |
| Like / recast | fc_react.sh | ✅ |
| Following feed | fc_feed.sh --following | ✅ |
| Channel feed | fc_feed.sh --channel | ❌ Paid |
| Cast search | fc_search.sh | ❌ Paid |
| Channel search/details/trending | fc_channels.sh | ❌ Paid |
| Delete cast | fc_delete.sh | ❌ Paid |
| Thread/conversation | fc_feed.sh --thread | ✅ |
Scripts that hit paid endpoints will exit non-zero with a clear 402 PaymentRequired error.
Error Handling
All scripts exit 0 on success, non-zero on failure. Errors print to stderr as JSON:
{"error": "message", "status": 403}
Common errors:
401— Invalid API key402— Feature requires paid Neynar plan403— Signer not approved or not paired with API key404— Cast/user/channel not found429— Rate limited (Neynar free tier: 300 req/min)
API Reference
See references/neynar_endpoints.md for the full endpoint list and parameter docs.
More by openclaw
View all skills by openclaw →You might also like
flutter-development
aj-geddes
Build beautiful cross-platform mobile apps with Flutter and Dart. Covers widgets, state management with Provider/BLoC, navigation, API integration, and material design.
drawio-diagrams-enhanced
jgtolentino
Create professional draw.io (diagrams.net) diagrams in XML format (.drawio files) with integrated PMP/PMBOK methodologies, extensive visual asset libraries, and industry-standard professional templates. Use this skill when users ask to create flowcharts, swimlane diagrams, cross-functional flowcharts, org charts, network diagrams, UML diagrams, BPMN, project management diagrams (WBS, Gantt, PERT, RACI), risk matrices, stakeholder maps, or any other visual diagram in draw.io format. This skill includes access to custom shape libraries for icons, clipart, and professional symbols.
godot
bfollington
This skill should be used when working on Godot Engine projects. It provides specialized knowledge of Godot's file formats (.gd, .tscn, .tres), architecture patterns (component-based, signal-driven, resource-based), common pitfalls, validation tools, code templates, and CLI workflows. The `godot` command is available for running the game, validating scripts, importing resources, and exporting builds. Use this skill for tasks involving Godot game development, debugging scene/resource files, implementing game systems, or creating new Godot components.
ui-ux-pro-max
nextlevelbuilder
"UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient."
nano-banana-pro
garg-aayush
Generate and edit images using Google's Nano Banana Pro (Gemini 3 Pro Image) API. Use when the user asks to generate, create, edit, modify, change, alter, or update images. Also use when user references an existing image file and asks to modify it in any way (e.g., "modify this image", "change the background", "replace X with Y"). Supports both text-to-image generation and image-to-image editing with configurable resolution (1K default, 2K, or 4K for high resolution). DO NOT read the image file first - use this skill directly with the --input-image parameter.
fastapi-templates
wshobson
Create production-ready FastAPI projects with async patterns, dependency injection, and comprehensive error handling. Use when building new FastAPI applications or setting up backend API projects.
Related MCP Servers
Browse all serversAccess Reddit API for posts, comments, profiles, subreddit info, search, writing actions, OAuth, analytics, and more wit
AI Memory is a production-ready vector database server that manages and retrieves contextual knowledge with advanced sem
Unlock Instagram insights to boost advertising and marketing services. Analyze interactions for better IG engagement and
Access Hacker News stories, comments, and profiles using the Firebase API with integrated hacker news algolia features a
Automate Twitter posts and engagement with auto tweet post, media uploads, and search features using secure API integrat
Access Reddit content with our API for subreddit search, post retrieval, and trend analysis. Efficient Reddit site searc
Stay ahead of the MCP ecosystem
Get weekly updates on new skills and servers.