From machina-sports-sports-skills
Fetches NCAA Division I FBS college football data from ESPN public endpoints: scores, standings, rosters, schedules, game summaries, play-by-play, rankings, injuries, futures, stats, news. For CFB queries.
npx claudepluginhub joshuarweaver/cascade-data-analytics --plugin machina-sports-sports-skillsThis skill uses the workspace's default tool permissions.
Before writing queries, consult `references/api-reference.md` for endpoints, conference IDs, team IDs, and data shapes.
Conducts multi-round deep research on GitHub repos via API and web searches, generating markdown reports with executive summaries, timelines, metrics, and Mermaid diagrams.
Dynamically discovers and combines enabled skills into cohesive, unexpected delightful experiences like interactive HTML or themed artifacts. Activates on 'surprise me', inspiration, or boredom cues.
Generates images from structured JSON prompts via Python script execution. Supports reference images and aspect ratios for characters, scenes, products, visuals.
Before writing queries, consult references/api-reference.md for endpoints, conference IDs, team IDs, and data shapes.
Before first use, check if the CLI is available:
which sports-skills || pip install sports-skills
If pip install fails with a Python version error, the package requires Python 3.10+. Find a compatible Python:
python3 --version # check version
# If < 3.10, try: python3.12 -m pip install sports-skills
# On macOS with Homebrew: /opt/homebrew/bin/python3.12 -m pip install sports-skills
No API keys required.
Prefer the CLI — it avoids Python import path issues:
sports-skills cfb get_scoreboard
sports-skills cfb get_rankings
sports-skills cfb get_standings --group=8
CRITICAL: Before calling any data endpoint, verify:
currentDate — never hardcoded.group parameter is set to the correct conference ID (see references/api-reference.md).get_teams to resolve the team ID.Derive the current year from the system prompt's date (e.g., currentDate: 2026-02-28 → current year is 2026).
season = current_year - 1. From August onward, use the current year.group parameter to filterrank field (null = unranked) on scoreboard competitors| Command | Description |
|---|---|
get_scoreboard | Live/recent college football scores |
get_standings | Standings by conference (use group parameter) |
get_teams | All 750+ FBS college football teams |
get_team_roster | Full roster for a team |
get_team_schedule | Schedule for a specific team |
get_game_summary | Detailed box score and scoring plays |
get_rankings | AP Top 25, Coaches Poll, CFP rankings |
get_news | College football news |
get_play_by_play | Full play-by-play for a game |
get_schedule | Season schedule by week |
get_injuries | Injury reports across all teams |
get_futures | Futures/odds markets (National Championship, Heisman, etc.) |
get_team_stats | Team statistical profile |
get_player_stats | Player statistical profile |
See references/api-reference.md for full parameter lists and return shapes.
Example 1: Current rankings User says: "What are the college football rankings?" Actions:
get_rankings()
Result: AP Top 25, Coaches Poll, and CFP rankings with rank, previous rank, recordExample 2: Conference standings User says: "Show me SEC football standings" Actions:
currentDateget_standings(group=8, season=<derived_year>) (group 8 = SEC)
Result: SEC standings with W-L records per teamExample 3: Team schedule User says: "What's Alabama's schedule this season?" Actions:
currentDateget_team_schedule(team_id="333", season=<derived_year>)
Result: Alabama's full season schedule with opponent, date, score (if played)Example 4: Weekly scores User says: "Show me this week's college football scores" Actions:
get_scoreboard()
Result: All live and recent CFB games with scores and ranked statusExample 5: Heisman favorites User says: "Who's the Heisman favorite?" Actions:
get_futures(limit=10)
Result: Top Heisman Trophy candidates with odds valuesExample 6: Team statistics User says: "Show me Alabama's team stats" Actions:
currentDateget_team_stats(team_id="333", season_year=<derived_year>)
Result: Alabama's season stats by category with value, rank, and per-game averagesget_oddsget_betting_oddssearch_teamsget_teams instead.get_box_scoreget_game_summary instead.get_player_ratingsget_player_stats instead.get_bcs_rankingsget_playoff_rankingsget_rankings instead.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:
Error: sports-skills command not found
Cause: Package not installed
Solution: Run pip install sports-skills
Error: No games found
Cause: CFB is seasonal (August–January); off-season scoreboard will be empty
Solution: Use get_rankings or get_news year-round; use get_schedule to find when the season starts
Error: Too many teams returned
Cause: get_teams returns 750+ FBS teams
Solution: Help users narrow down by suggesting specific team IDs from references/api-reference.md, or use ESPN URLs to look up IDs
Error: Rankings empty in off-season
Cause: Rankings are only published during the season and early off-season
Solution: Use get_news in the offseason; rankings resume in August