skills/xctf-data/SKILL.md
NCAA cross country and track & field athlete data via TFRRS (tfrrs.org) and news via The Stride Report. Fetch athlete profiles including all personal records (PRs), eligibility year, school, full season-by-season results history, and XC/TF news. Zero config, no API keys. Use when: user asks about NCAA cross country, NCAA track and field, college running, TFRRS athlete profiles, personal records, PRs, XC or TF season results, individual athlete performance history, or XC/TF news. Don't use when: user asks about professional track, Diamond League, or other sports — use nfl-data, nba-data, wnba-data, nhl-data, mlb-data, golf-data, cricket-data, cfb-data, cbb-data, tennis-data, fastf1, or volleyball-data. For betting use polymarket or kalshi.
npx skillsauth add machina-sports/sports-skills xctf-dataInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Before writing queries, consult references/api-reference.md for parameters, URL conventions, and return shapes.
Before first use, check if the CLI is available:
which sports-skills || pip install sports-skills
If pip install fails, install from GitHub:
pip install git+https://github.com/machina-sports/sports-skills.git
Requires Python 3.10+. No API keys required. All data comes from TFRRS public pages and The Stride Report RSS feed.
CLI (preferred):
sports-skills xctf get_athlete_profile --athlete_id=9230145 --school=BYU --name=Jane_Hedengren
sports-skills xctf get_news --limit=5
Python SDK:
from sports_skills import xctf
profile = xctf.get_athlete_profile(
athlete_id="9230145",
school="BYU",
name="Jane_Hedengren",
)
All three parameters are required and must match the athlete's TFRRS URL exactly:
https://www.tfrrs.org/athletes/{athlete_id}/{school}/{name}.html
athlete_id — numeric ID (e.g. 9230145)school — school slug with underscores, not spaces (e.g. BYU)name — athlete name slug (e.g. Jane_Hedengren)Do NOT guess slugs. Find them by navigating to the athlete on tfrrs.org and copying the URL.
| Command | Description |
|---|---|
| search_athlete | Search the current team roster by name; returns athlete_id, school, and name slugs for use with get_athlete_profile. Searches both genders automatically. Current athletes only — graduated athletes require a direct TFRRS URL |
| get_athlete_profile | Athlete name, school, eligibility, all PRs, and full season-by-season meet results |
| get_team_roster | Full XC and/or TF roster for a team |
| get_meet_results | All event results and team scores from a TFRRS meet |
| get_news | Recent XC/TF articles from The Stride Report (thestridereport.com) |
See references/api-reference.md for full parameter details and return shapes.
Example 1: Look up a current athlete's PRs User says: "What are Jane Hedengren's PRs?" Actions:
search_athlete(name="Jane Hedengren", school="UT_college_f_BYU")
Result: data.matches contains entries with athlete_id, school, name slugsget_athlete_profile(athlete_id="9230145", school="BYU", name="Jane_Hedengren")
Result: data.prs contains all personal records by event (e.g. {"1500": "4:10.24", "5000": "14:44.79", "6K (XC)": "18:29.6", ...})Example 2: Get a runner's cross country season User says: "Show me Jane Hedengren's 2025 XC season results" Actions:
search_athlete(name="Jane Hedengren", school="UT_college_f_BYU")get_athlete_profile with the matched athlete paramsdata.meets for entries whose date falls in the fall of 2025 (Sep–Nov 2025)
Result: List of meets with dates, events, marks, and placesExample 3: Graduated or transferred athlete User says: "What are Katelyn Vuong's PRs from UC Davis?" Actions:
search_athlete(name="Katelyn Vuong", school="CA_college_f_UC_Davis")
Result: data.matches is empty — athlete has graduatedhttps://www.tfrrs.org/athletes/7899206/UC_Davis/Katelyn_Vuong.htmlget_athlete_profile(athlete_id="7899206", school="UC_Davis", name="Katelyn_Vuong")
Note: TFRRS creates separate profiles for XC and TF. If both exist, fetch both IDs for complete PRs.Example 4: Get a team's current roster User says: "Show me the UC Davis women's XC roster" Actions:
get_team_roster(school="CA_college_f_UC_Davis", sport="xc")
Result: List of athletes with name, year, and profile slugsExample 5: Get results from a meet User says: "Show me the results from the Stanford Invitational" Actions:
get_meet_results(meet_id="95890", slug="Stanford_Invitational")
Result: All event results and team scores from the meetExample 6: Get the latest XC/TF news User says: "What's the latest college track news?" Actions:
get_news(limit=10)
Result: Recent articles from The Stride Report with title, date, summary, and linkget_team_rankings~~ — does not exist. Use get_athlete_profile for individual data.search_athletes~~ — does not exist. The correct command is search_athlete (no trailing 's').fetch_news~~ — does not exist. The correct command is get_news.If a command is not listed in the Commands table above, it does not exist.
When a command fails, do not surface raw errors to the user. Instead:
get_athlete_profile: confirm athlete_id, school, and name match the TFRRS URL exactly (case-sensitive)search_athlete: verify the team slug is correct by checking the team's TFRRS page URLget_meet_results: verify the meet_id and slug match the meet's TFRRS URL exactlyget_team_roster: verify the school slug is correctget_news: if the feed fails, inform the user that The Stride Report may be temporarily unavailablesports-skills command not found
Run pip install sports-skills or install from GitHub (see Setup above).
HTTP 404 on athlete profile
The school or name slug does not match the TFRRS URL exactly. Slugs are case-sensitive and use underscores. Copy directly from tfrrs.org.
prs returns empty dict
The athlete's profile page may be very new or structured differently. Check the URL directly on tfrrs.org.
search_athlete returns empty matches
The athlete is likely graduated or transferred. See Example 3 above for how to handle this.
get_meet_results returns no events
The meet_id or slug may be incorrect. Copy both directly from the meet's TFRRS URL.
get_news fails or returns no articles
The Stride Report RSS feed may be temporarily unavailable. Try again later.
Connection errors or timeouts TFRRS may be temporarily unavailable. Requests are throttled to 1 per second automatically — wait a moment and retry.
tools
Premium FIFA World Cup 2026 market & match intelligence — a hosted, read-only layer that fuses official match truth (fixtures, standings, squads, injuries, player performance) with live prediction markets (Kalshi + Polymarket: prices, order books, price history, movers, cross-venue edges) and AI-grounded context (prematch briefs, move explanations, fan/social pulse). Every entity carries a canonical machina URN cross-walked across api-football, sportradar, opta, entain and ESPN, so a market resolves to a fixture resolves to two teams. This skill is prompt-only and premium: it routes the agent to the hosted World Cup Intelligence project (a per-project Machina MCP server) via `machina-cli`. It runs no code locally and ships no API keys. Use when: the user wants World Cup 2026 odds + match context together, asks "what moved and why", wants a grounded market brief or fan-sentiment read on a fixture, or needs one stable id that joins markets ↔ fixtures ↔ teams across providers. Don't use when: the user wants free snapshot data from public APIs (use the `football-data`, `kalshi`, `polymarket`, or `markets` skills), or wants to place a bet/trade — this layer is read-only intelligence and never executes orders.
development
Sports metadata via TheSportsDB free API (key=3). Team logos and badges, player photos, stadium info, league info, and biographical data across 100+ leagues. No API key required, zero config. Use when: user asks for a team logo, crest, badge, banner, jersey, kit, player photo or headshot, stadium info, club description, or wants to search for teams or players by name across sports. Good for enriching responses from other skills with images and visual identifiers. Don't use when: user asks for scores, standings, fixtures, stats, or odds — use the sport-specific skill instead: football-data (soccer), nfl-data (NFL), nba-data (NBA), wnba-data (WNBA), nhl-data (NHL), mlb-data (MLB), tennis-data (tennis), golf-data (golf), cricket-data (cricket), cfb-data (college football), cbb-data (college basketball), fastf1 (F1), volleyball-data (Dutch volleyball), xctf-data (NCAA XC/TF). Don't use for prediction markets — use polymarket or kalshi.
development
Cricket data via ESPN public endpoints and Cricsheet open data — live-ish series scoreboards, standings, match summaries and news (ESPN), plus historical ball-by-ball, player stats, and player registry (Cricsheet, ODC-BY 1.0). Zero config, no API keys. Use when: user asks about cricket scores, IPL/BBL/PSL/international series, points tables, match details, cricket news, ball-by-ball history, or player career stats. Don't use when: user asks about other sports — use football-data (soccer), nfl-data (NFL), nba-data (NBA), wnba-data (WNBA), nhl-data (NHL), mlb-data (MLB), tennis-data (tennis), golf-data (golf), cfb-data (college football), cbb-data (college basketball), or fastf1 (F1). For betting odds use polymarket or kalshi. For general news use sports-news. Don't use for ICC rankings — no free source exists (v1 limitation).
development
Dutch volleyball data (Eredivisie, Topdivisie, Superdivisie, and the full Dutch pyramid) via the Nevobo API. Standings, schedules, results, clubs, tournaments, and news. Zero config, no API keys. Use when: user asks about Dutch volleyball, Eredivisie volleyball, Nevobo, volleyball standings, volleyball match results, volleyball schedules, or Dutch volleyball clubs. Don't use when: user asks about other sports — use football-data (soccer), nfl-data (NFL), nba-data (NBA), wnba-data (WNBA), nhl-data (NHL), mlb-data (MLB), golf-data (golf), cricket-data (cricket), cfb-data (college football), cbb-data (college basketball), tennis-data (tennis), or fastf1 (F1). For betting odds use polymarket or kalshi. For general news use sports-news.