Prediction Bridge Dev
--- name: prediction-bridge-search description: Search Prediction Bridge prediction-market events by text or X (Twitter) link via the backend API. homepage: https://www.predictionbridge.xyz metadata:
Description
name: prediction-bridge-search description: Search Prediction Bridge prediction-market events by text or X (Twitter) link via the backend API. homepage: https://www.predictionbridge.xyz metadata: {"openclaw":{"skillKey":"prediction-bridge-search","homepage":"https://www.predictionbridge.xyz","requires":{"bins":["curl"]}}}
Use this skill when the user wants to find relevant prediction markets/events for:
- a short text query (topic, question, headline)
- a URL to an article
- an X (Twitter) status link (the backend resolves and extracts the tweet text)
Usage scenarios (when to use)
Use this skill when the user asks:
- “Find prediction markets for this topic/headline”
- “What markets match this tweet/X link?”
- “Search Polymarket/Kalshi for events about …”
This skill is best for:
- turning unstructured text (or an X URL) into ranked, actionable event links
- quickly surfacing the top 5–10 matches with a brief market snapshot
Not a good fit when the user wants:
- full market orderbooks or historical candles (use the market-data endpoints instead)
- deep-dive sentiment/timeline generation (use the event deep-dive endpoints instead)
This skill calls the existing Prediction Bridge backend endpoint:
POST /api/v1/search/unified
It returns matched events (prediction market events) and optionally matched news.
Configuration
API base (defaults to production):
PREDICTION_BRIDGE_API_URL
Defaults:
- Production:
https://prediction-bridge.onrender.com/api/v1 - Local dev (if you run the backend locally):
http://localhost:8000/api/v1
How to run
- Build the query text
- If the user provides an X status link, pass the URL as
textunchanged. The backend will resolve it. - If the user provides plain text, pass it as-is.
- Call unified search
Use exec with curl:
API_URL="${PREDICTION_BRIDGE_API_URL:-https://prediction-bridge.onrender.com/api/v1}"
curl -sS -X POST "$API_URL/search/unified" \
-H "Content-Type: application/json" \
-H "X-Request-ID: pb-$(date +%s)" \
--data-binary @- <<'JSON'
{
"text": "<USER_TEXT_OR_X_URL>",
"limit": 10,
"offset": 0,
"include_inactive": false,
"include_markets": true,
"markets_per_event": 1,
"include_translations": false
}
JSON
Notes:
- Use
markets_per_event: 1to keep payload small but still show the leading market. - If the user explicitly asks for more markets per event, increase
markets_per_event.
API response format (what you will receive)
POST /search/unified returns JSON with this shape (fields may be omitted or null depending on data availability):
{
"source": {
"type": "x" ,
"url": "https://x.com/.../status/...",
"text": "resolved tweet text (optional)",
"id": "optional"
},
"events": [
{
"score": 0.82,
"event": {
"id": 123,
"title": "...",
"description": "...",
"source": "polymarket",
"source_url": "https://polymarket.com/event/...",
"status": "active",
"volume_usd": 12345.67,
"liquidity_usd": 2345.0,
"end_date": "2026-12-31T00:00:00Z",
"markets": [
{
"id": 999,
"question": "...",
"outcomes": ["Yes", "No"],
"outcome_prices": {"Yes": 0.61, "No": 0.39},
"volume": 1000.0,
"active": true,
"closed": false
}
]
}
}
],
"news": [
{
"score": 0.74,
"news": {
"id": 456,
"title": "...",
"summary": "...",
"url": "https://...",
"image_url": "https://...",
"source": "...",
"published_at": "2026-02-01T12:34:56Z"
}
}
]
}
Key points:
events[]is the primary output. Each item has{ score, event }.scoreis a relevance score; higher is better.event.marketsis present when you requestedinclude_markets: true.- When you set
markets_per_event, the backend may return only a preview subset.
- When you set
news[]is optional supporting context; do not let it crowd out event results.
How the agent should parse + handle results
Important:
- Do NOT show the raw JSON response to the user.
- Always parse/validate the response first, then present the matched
eventsas a clean, human-readable list.
- Validate payload shape
- Treat missing/invalid JSON as a failure and retry once (or ask the user to retry).
- If
eventsis missing or not an array, treat it as empty.
- Rank and select
- Sort
eventsbyscoredescending (even if the backend already sorted). - Default to presenting top 5 results; show up to 10 if the user asked for “more”.
- Extract a “market snapshot” per event (best-effort)
- Prefer
event.source_urlas the click-through link. - If
event.source_urlis missing, fall back to the frontend detail page:https://www.predictionbridge.xyz/event/<event.id>
- If
event.markets[0].outcome_pricesexists:- show the YES/Long price if present:
outcome_prices.Yesoroutcome_prices.Long - otherwise show the first available outcome price
- show the YES/Long price if present:
- Present concise output
- For each event, output:
- Title
- Source/platform (
event.source) - Relevance score (rounded, e.g. 0.82)
- Link (
event.source_urlpreferred) - 1-line snapshot: probability (if available) + volume/liquidity (if available)
- Optional: include related news
- If
newsexists, include at most 1–3 items with title + URL as extra context.
- Empty results
- If
eventsis empty:- say no strong matches found
- ask for 1 clarifying detail (timeframe, geography, person/org name, or paste the text instead of a shortened link)
How to present results
After you receive JSON:
- If
eventsis empty, say no matches were found and ask for a more specific query. - Otherwise list the top results (usually 5–10):
- event title
- platform/source (e.g. Polymarket, Kalshi)
- score (higher is better)
- a link to the event (
event.source_urlwhen present) - quick market snapshot (from the first market in
event.markets, if present)
If news is present, optionally show 1–3 related news items as context.
Error handling
- HTTP 400: invalid input or X resolve error → ask the user to paste a different link or provide plain text.
- HTTP 503: backend DB unavailable → suggest retrying later.
- Any network error: confirm
PREDICTION_BRIDGE_API_URLand whether the API is reachable.
Reviews (0)
No reviews yet. Be the first to review!
Comments (0)
No comments yet. Be the first to share your thoughts!