A powerful serverless AI agent template for Cloudflare Workers that supports multiple platforms (Twitter, Telegram, Farcaster) with built-in memory management and LLM integration.
Create a new project using this template:
npm create cloudflare@latest -- my-first-worker --template 0xkoda/fagent
If you are using cursor or windsurf, or another AI enabled code editor, you may benefit from cursor rules.
-
Twitter Setup
- API-based Authentication:
- Set
ENABLE_TWITTER=true
in wrangler.toml - Add Twitter API credentials:
npx wrangler secret put TWITTER_API_KEY npx wrangler secret put TWITTER_API_SECRET npx wrangler secret put TWITTER_ACCESS_TOKEN npx wrangler secret put TWITTER_ACCESS_SECRET
- Set
- API-based Authentication:
-
Telegram Setup
- Create a new bot through @BotFather
- Record the bot token for later use
- After deployment, set webhook:
curl -F "url=https://your-worker-url/telegram" https://api.telegram.org/bot<YOUR_BOT_TOKEN>/setWebhook
-
Farcaster Setup
- Create/login to Neynar account
- Generate a signer UUID in the dashboard
- Create a new agent account if needed (can be done from dashboard)
- Record your API key and signer UUID
- Create the KV namespace:
npx wrangler kv:namespace create AGENT_KV
- Add the returned values to your
wrangler.toml
:
# KV namespace for agent memory
[[kv_namespaces]]
binding = "agent_memory"
id = "" # Add your KV namespace ID here
preview_id = "" # Add your preview ID here
This is an optional feature that can be set inside your wrangler.toml with USE_CF_GATEWAY = true # Toggle for Cloudflare AI Gateway
Cloudflare AI Gateway provides centralized visibility and control for your AI applications. Enable AI gateway in your Cloudflare dashboard, create a gateway ID, and add the variables to the wrangler.toml. This will enable features like cost tracking across OpenRouter calls, observability, caching and evals.
- Multi-platform support (Twitter, Telegram, Farcaster)
- Twitter posts only (no replies or slop)
- Two-tier memory system with Cloudflare KV (long and short-term memory)
- Custom action system for handling commands
- Scheduled jobs support
- Open Router LLM integration for intelligent responses
The agent includes a sophisticated two-tier memory system:
- Conversation Memory: 24-hour TTL for recent interactions
- Long-term Memory: 30-day TTL for persistent knowledge
Memory is automatically managed through Cloudflare KV.
Create your agent's persona in ./config/character.json
. This defines your agent's personality and behavior.
- Register new actions in the
/actions
directory - Add your action to
./actions/index.ts
Add required secrets using wrangler:
# Add platform-specific secrets
npx wrangler secret put TELEGRAM_BOT_TOKEN
npx wrangler secret put FARCASTER_NEYNAR_API_KEY
npx wrangler secret put FARCASTER_NEYNAR_SIGNER_UUID
npx wrangler secret put FARCASTER_FID
npx wrangler secret put TWITTER_API_KEY
npx wrangler secret put TWITTER_API_SECRET
npx wrangler secret put TWITTER_ACCESS_TOKEN
npx wrangler secret put TWITTER_ACCESS_SECRET
# Add LLM API key
npx wrangler secret put OPENROUTER_API_KEY
This template uses OpenRouter to access various LLM models. OpenRouter provides a unified API to access models from different providers including OpenAI, Anthropic, and others.
- Get your API key from OpenRouter
- Add the API key to your secrets:
npx wrangler secret put OPENROUTER_API_KEY
- Configure your preferred model in
wrangler.toml
:
[vars]
LLM_MODEL = "openai/gpt-3.5-turbo" # Model to use for LLM responses
Available models can be found in the OpenRouter documentation.
Configure platform settings in wrangler.toml
:
[vars]
ENABLE_FARCASTER = true # Enable/disable Farcaster
ENABLE_TELEGRAM = true # Enable/disable Telegram
ENABLE_TWITTER = false # Enable Twitter API client
USE_CF_GATEWAY = true # Optional: Toggle for Cloudflare AI Gateway
CF_ACCOUNT_ID = "" # Optional: Cloudflare Account ID for AI gateway
CF_GATEWAY_ID = "" # Optional: Cloudflare Gateway ID
Scheduled jobs can define how your agent interfaces with social clients, like regular posts. Scheduled jobs can perform an action or group of actions.
The agent supports scheduled jobs through the scheduler.ts
and scheduled.ts
files in the src/jobs
directory.
For detailed examples and implementation details, see the Creating Scheduled Jobs section in the documentation.
- Configure the cron schedule in
wrangler.toml
:
[triggers]
crons = ["30 12 * * *"] # Runs at 12:30 UTC daily
-
Character Refinement Define your character in ./config/character.json
-
Deploy Your Worker
npx wrangler deploy
- Post-Deployment
- Configure Telegram webhook with your worker URL
- Set up Neynar webhook in the dashboard with your worker URL
- Test your bot's functionality on both platforms
- Add any custom actions
- Add any scheduled jobs (see Creating Scheduled Jobs)
- Enhance memory system with vectorDB
- Add more platform integrations
Contributions are welcome! Please feel free to submit a Pull Request.