Quick links
- Live demo: cometchat.github.io/ai-agent-mastra-examples/product-hunt-agent/web
- Source code: GitHub repository
What you’ll build
- A Mastra agent that can:
- Get top Product Hunt posts by timeframe or all‑time by votes
- Search posts via Product Hunt’s public Algolia index
- Answer practical “how to launch on Product Hunt” questions
- Trigger a confetti animation in the user’s browser (frontend action)
 
- A tiny HTTP API that exposes /api/top*,/api/search, and/api/chat
- A static Product Hunt‑style page (with CometChat widget) that handles the confetti tool
- src/mastra/agents/producthunt-agent.ts— the agent definition
- src/mastra/tools/producthunt-tools.ts— tools: top products, timeframe top, search, confetti
- src/services/producthunt.ts— Product Hunt GraphQL + Algolia helpers and timeframe parsing
- src/server.ts— minimal API server returning JSON and agent chat
- web/index.html— static UI that mounts CometChat and maps the confetti tool
Prerequisites
- Node.js 20+
- OpenAI API key in your environment as OPENAI_API_KEY(agent Q&A)
- Product Hunt API token as PRODUCTHUNT_API_TOKEN(for top posts)
- A CometChat app (for the widget on the static page)
- Runtime & scripts: package.json
- Server TS build: tsconfig.server.json
- Static page: web/index.html
How it works
- The agent (model: OpenAI via @ai-sdk/openai) can call tools:- get-top-products— top all‑time by votes (GraphQL)
- get-top-products-by-timeframe— top posts for a day/week/month/date range with timezone
- search-products— search via Algolia public index
- confetti-tool— returns a structured payload the frontend uses to fire confetti
 
- The API server exposes:
- GET /api/top,- GET /api/top-week,- GET /api/top-range— fetch posts
- GET /api/search— Algolia search
- POST /api/chat— chat with the agent; server streams model text and returns- { reply }
 
- The static page uses the CometChat Embed, and registers a client‑side tool handler map. When a chat message triggers confetti-tool, the page loadscanvas-confettiand fires it with the provided options.
Step 1 — Define tools
File:src/mastra/tools/producthunt-tools.ts
- Top/all‑time: get-top-products
- Timeframe: get-top-products-by-timeframe(supports today/yesterday/this‑week/last‑week/this‑month/last‑month, single date YYYY‑MM‑DD, orfrom:YYYY-MM-DD to:YYYY-MM-DDranges; default tzAmerica/New_York)
- Search: search-productsvia Algolia public GET with fixed public headers
- Frontend action: confetti-toolreturns a payload with particleCount, colors, origin, etc.
Step 2 — Create the agent
File:src/mastra/agents/producthunt-agent.ts
Checklist for the agent:
- Name it clearly (e.g., “Product Hunt Agent”)
- Explain when to use each tool, especially timeframe vs. all‑time
- Keep launch‑advice answers concise and actionable
- Include links when returned by tools; omit when missing
- Be graceful when APIs are missing (empty arrays)
Step 3 — Wire Mastra (optional)
File:src/mastra/index.ts
- Register your agent into Mastra if you prefer the Mastra dev server workflow
- This demo uses a custom minimal src/server.tsfor a simple/api/*shape
Step 4 — Run locally
- Install dependencies
- Build server TypeScript
- Start the server
- Open the static page
http://localhost:8787
Environment variables:
- OPENAI_API_KEY— required for agent chat
- PRODUCTHUNT_API_TOKEN— required for live top posts; without it- /api/top*return empty arrays
Step 5 — Frontend actions handler
File:web/index.html
- Registers tool handlers:
- confetti-tool(and- confettiTool) → loads- canvas-confettion demand, or uses a fallback renderer
 
- CometChat Embed is initialized and launched; when the agent returns a tool call tied to the widget configuration, your handler runs it
Step 6 — API overview
- GET /api/health→- { ok: true }
- GET /api/top?limit=3→ top all‑time by votes
- GET /api/top-week?limit=3&days=7→ rolling week by ranking
- GET /api/top-range?timeframe=today&tz=America/New_York&limit=3→ timeframe window by ranking
- GET /api/search?q=term&limit=10→ Algolia search
- POST /api/chatwith- { message }→- { reply }from the agent
Step 7 — Deploy the API
- Deploy src/server.ts(Node 20+) to your hosting (Render, Fly, Vercel functions with Node runtime, etc.)
- Set OPENAI_API_KEYandPRODUCTHUNT_API_TOKENin the host environment
- Point the static page to your public API by setting window.PH_AGENT_API
Step 8 — Connect in CometChat
- Open the CometChat Dashboard → your App → AI Agents
- Add an agent with Provider=Mastra, Agent ID matching your integration, and the public generate/chat endpoint
- Ensure your frontend (widget or custom UI) maps the confetti-toolID to your handler function
Step 9 — Test
- Hit /api/healthto confirm server is up
- Try /api/search?q=notionto verify Algolia access
- Call /api/top-range?timeframe=todaywith a valid token to get live posts
- POST /api/chatwith a prompt like “Celebrate our launch with confetti” and verify the frontend fires confetti when wired via CometChat
Security & production checklist
- Keep API tokens server‑side; never expose OPENAI_API_KEYor Product Hunt tokens to the client
- Add auth (API key/JWT), restrict CORS, and rate‑limit endpoints
- Validate and clamp user inputs (limits, timeframes)
- Log server errors, not secrets
Troubleshooting
- No posts from /api/top*: missing or invalidPRODUCTHUNT_API_TOKEN
- Empty /api/search: network block to Algolia; verify headers and URL
- Chat has generic replies only: OPENAI_API_KEYmissing
- Confetti not firing: verify tool ID mapping (confetti-toolorconfettiTool) and that the handler loadscanvas-confetti