hotsaucejake / laravel-sleeper
An API wrapper for the fantasy sleeper app
Installs: 36
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 1
pkg:composer/hotsaucejake/laravel-sleeper
Requires
- php: ^8.2|^8.3|^8.4
- guzzlehttp/guzzle: ^7.5
- illuminate/contracts: ^9.0|^10.0|^11.0|^12.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^6.0|^7.0|^8.0|^9.0
- orchestra/testbench: ^7.0|^8.0|^9.0|^10.0
- pestphp/pest: ^1.21|^2.0|^3.0
- pestphp/pest-plugin-laravel: ^1.1|^2.0|^3.0
- phpunit/phpunit: ^9.5|^10.0|^11.0|^12.0
- vlucas/phpdotenv: ^5.5
This package is auto-updated.
Last update: 2025-10-13 18:03:37 UTC
README
A comprehensive Laravel package for interacting with the Sleeper Fantasy Sports API. This package provides easy access to all Sleeper API endpoints including users, leagues, drafts, players, and more.
Official Sleeper Resources:
Installation
You can install the package via composer:
composer require hotsaucejake/laravel-sleeper
API Overview
The Sleeper API is read-only and requires no authentication. All methods return JSON objects/arrays containing the requested data. Rate limit: stay under 1000 calls per minute.
Complete Usage Guide
use HOTSAUCEJAKE\LaravelSleeper\Facades\LaravelSleeper;
👤 User Endpoints
getUserByName(string $username)
Retrieves user information by username.
$user = LaravelSleeper::getUserByName('sleeperuser'); // Returns: { "username": "sleeperuser", "user_id": "12345678", "display_name": "SleeperUser", "avatar": "..." }
getUserById(string $user_id)
Retrieves user information by user ID. Recommended over username since usernames can change.
$user = LaravelSleeper::getUserById('12345678'); // Returns: Same format as getUserByName()
🖼️ Avatar Endpoints
showAvatar(string $avatar_id)
Returns the full-size avatar URL for a given avatar ID.
$avatarUrl = LaravelSleeper::showAvatar('cc12ec49965eb7856f84d71cf85306af'); // Returns: "https://sleepercdn.com/avatars/cc12ec49965eb7856f84d71cf85306af"
showAvatarThumbnail(string $avatar_id)
Returns the thumbnail avatar URL for a given avatar ID.
$thumbnailUrl = LaravelSleeper::showAvatarThumbnail('cc12ec49965eb7856f84d71cf85306af'); // Returns: "https://sleepercdn.com/avatars/thumbs/cc12ec49965eb7856f84d71cf85306af"
🏆 League Endpoints
getAllLeaguesForUser(string $user_id, int $season, string $sport = 'nfl')
Retrieves all leagues for a specific user in a given season.
$leagues = LaravelSleeper::getAllLeaguesForUser('12345678', 2024); // Returns: Array of league objects with settings, roster info, scoring settings, etc.
getLeague(string $league_id)
Retrieves detailed information about a specific league.
$league = LaravelSleeper::getLeague('289646328504385536'); // Returns: Single league object with full configuration details
getLeagueRosters(string $league_id)
Retrieves all rosters in a league with current players, starters, and team records.
$rosters = LaravelSleeper::getLeagueRosters('289646328504385536'); // Returns: Array of roster objects with starters[], players[], settings{wins, losses, points}, etc.
getLeagueUsers(string $league_id)
Retrieves all users/managers in a league with their team information.
$users = LaravelSleeper::getLeagueUsers('289646328504385536'); // Returns: Array of user objects with metadata{team_name}, is_owner (commissioner status), etc.
getLeagueMatchups(string $league_id, int $week)
Retrieves all matchups for a specific week. Teams with the same matchup_id
play each other.
$matchups = LaravelSleeper::getLeagueMatchups('289646328504385536', 1); // Returns: Array with starters[], players[], matchup_id, points, custom_points
getLeaguePlayoffWinnersBracket(string $league_id)
Retrieves the winners bracket for league playoffs.
$bracket = LaravelSleeper::getLeaguePlayoffWinnersBracket('289646328504385536'); // Returns: Array of bracket rounds with team progressions and results
getLeaguePlayoffLosersBracket(string $league_id)
Retrieves the losers bracket for league playoffs (consolation bracket).
$bracket = LaravelSleeper::getLeaguePlayoffLosersBracket('289646328504385536'); // Returns: Array of bracket rounds for consolation games
getLeagueTransactions(string $league_id, int $round)
Retrieves all transactions (trades, waivers, free agents) for a specific week/round.
$transactions = LaravelSleeper::getLeagueTransactions('289646328504385536', 1); // Returns: Array of transactions with type, adds{}, drops{}, draft_picks[], waiver_budget[]
getLeagueTradedPicks(string $league_id)
Retrieves all traded draft picks in a league, including future picks.
$tradedPicks = LaravelSleeper::getLeagueTradedPicks('289646328504385536'); // Returns: Array with season, round, roster_id (original), owner_id (current)
getSportState(string $sport = 'nfl')
Retrieves current state information for the sport (current week, season, etc.).
$state = LaravelSleeper::getSportState('nfl'); // Returns: { week, season_type, season, previous_season, league_season, display_week }
📋 Draft Endpoints
getDraftsForUser(string $user_id, int $season, string $sport = 'nfl')
Retrieves all drafts for a specific user in a given season.
$drafts = LaravelSleeper::getDraftsForUser('12345678', 2024); // Returns: Array of draft objects with type, status, settings, metadata
getLeagueDrafts(string $league_id)
Retrieves all drafts for a specific league (dynasty leagues may have multiple drafts).
$drafts = LaravelSleeper::getLeagueDrafts('289646328504385536'); // Returns: Array of draft objects sorted by most recent
getSpecificDraft(string $draft_id)
Retrieves detailed information about a specific draft.
$draft = LaravelSleeper::getSpecificDraft('289646328508579840'); // Returns: Draft object with draft_order{}, slot_to_roster_id{}, settings{}
getDraftPicks(string $draft_id)
Retrieves all picks made in a specific draft with player details.
$picks = LaravelSleeper::getDraftPicks('289646328508579840'); // Returns: Array of picks with player_id, picked_by, roster_id, round, metadata{player info}
getDraftTradedPicks(string $draft_id)
Retrieves all traded picks within a specific draft.
$tradedPicks = LaravelSleeper::getDraftTradedPicks('289646328508579840'); // Returns: Array similar to league traded picks but specific to this draft
🏈 Player Endpoints
getAllPlayers(string $sport = 'nfl')
Retrieves all players in the database. Important: This is a large response (~5MB) - cache locally and call max once per day.
$players = LaravelSleeper::getAllPlayers('nfl'); // Returns: Object with player_id as keys, player objects with name, position, team, stats, etc.
getTrendingPlayers(string $type = 'add', string $sport = 'nfl', int $lookback_hours = 24, int $limit = 25)
Retrieves trending players based on add/drop activity.
// Most added players in last 24 hours $trending = LaravelSleeper::getTrendingPlayers('add'); // Most dropped players in last 48 hours, limit 10 $dropped = LaravelSleeper::getTrendingPlayers('drop', 'nfl', 48, 10); // Returns: Array of { player_id, count } objects
💡 Usage Tips
Working with Player IDs
Player IDs can be numeric strings ("1042"
) or team abbreviations ("CAR"
for team defenses).
// Get all players to create a lookup map $players = LaravelSleeper::getAllPlayers(); $playerName = $players['1042']['first_name'] . ' ' . $players['1042']['last_name']; $teamDefense = $players['CAR']['position']; // "DEF"
Finding Matchup Results
Teams with the same matchup_id
play against each other:
$matchups = LaravelSleeper::getLeagueMatchups('league_id', 1); foreach ($matchups as $team) { // Find opponent by matching matchup_id $opponent = collect($matchups)->where('matchup_id', $team['matchup_id']) ->where('roster_id', '!=', $team['roster_id']) ->first(); }
Calculating Bench Players
Bench players = All players - Starting players:
$roster = LaravelSleeper::getLeagueRosters('league_id')[0]; $bench = array_diff($roster['players'], $roster['starters']);
Testing
In order to run the package tests you must create an .env
file from the .env.example
file. Tests will use the live endpoints. Since it's under the API rate limit, it's ok for now. I don't think this package will get any bigger than it already is so no need for mocks, etc...
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.